【ARM64 常见汇编指令学习 14 -- ARM 汇编 .balign,.balignw,.balign 伪指令学习】

文章目录

    • [.balign,.balignw,.balign 介绍](#.balign,.balignw,.balign 介绍)

上篇文章:ARM64 常见汇编指令学习 13 -- ARM 汇编 ORG 伪指令学习
下篇文章:ARM64 常见汇编指令学习 15 -- ARM 标志位的学习

.balign,.balignw,.balign 介绍

.balignl 是一个伪操作符,伪操作符的意思就是机器码里,并没有一个汇编指令与其对应,是编译器来实现其功能的。.balignl.balign的变体。

.balignl 完整指令格式为:

c 复制代码
.balignl {alignment} {,fill} {,max}
  • 第一个参数alignment为一个正整数,以alignment的值的整数倍为结束地址进行对齐,以当前地址为起始地址,进行字节填充,比如当前地址为20,而alignment的值我们设定为16,那么字节填充自20开始,结束于20后第一个16的倍数地址处,即32处。

  • 第二个参数fill即我们选定的,用来填充的数值。balignl模式下为4字节 ,不够4字节系统会自动补够4字节,此参数可选,不标则采用默认值0

  • 第三个参数max也是可选项,默认值为alignment。若对齐时偏移量大于max,则不偏移。同上例,从16--32,偏移量为16,如果max我们设置为8,那么该偏移不进行。

.balignw 表示逐半字(2个字节)的填充第2个参数(第2个参数是2个字节的值);
.balign 表示 1个字节1字节的填充 第2个参数值(第2个参数是1个字节的值)。

比如 ARM64 中断向量表的首地址是2K 对齐,我们就可以按照下面方式进行配置:

c 复制代码
  .balign 0x800
vector_table:
        POST_CODE 0xB0B0
        b         .
        .balign 0x80
        POST_CODE 0xB0B1
        b         .
        .balign 0x80
        POST_CODE 0xB0B2
        b         .
        .balign 0x80
        POST_CODE 0xB0B3
        b         .
        .balign 0x80
        POST_CODE 0xB0B4
        b         .
        .balign 0x80
        POST_CODE 0xB0B5
        b         .
        .balign 0x80
        POST_CODE 0xB0B6
        b         .
        .balign 0x80
        POST_CODE 0xB0B7
        b         .
        .balign 0x80
        POST_CODE 0xB0B8
        bl   ASM_PFX(warm_reset)
        b         .
        .balign 0x80
        POST_CODE 0xB0B9
        b         .
        .balign 0x80
        POST_CODE 0xB0BA
        b         .
        .balign 0x80
        POST_CODE 0xB0BB
        b         .
        .balign 0x80
        POST_CODE 0xB0BC
        b         .
        .balign 0x80
        POST_CODE 0xB0BD
        b         .
        .balign 0x80
        POST_CODE 0xB0BE
        b         .
        .balign 0x80
        POST_CODE 0xB0BF
        b 

POST_CODE 定义:

c 复制代码
.macro  POST_CODE, val
  mov  x23, x0
  mov  x0, #\val
  bl   ASM_PFX(PostCode_S)
  mov  x0, x23
.endm

上篇文章:ARM64 常见汇编指令学习 13 -- ARM 汇编 ORG 伪指令学习
下篇文章:ARM64 常见汇编指令学习 15 -- ARM 标志位的学习

相关推荐
YLAD9 小时前
gnu arm toolchain中的arm-none-eabi-gdb.exe的使用方法?
arm开发
饶宇航10 小时前
嵌入式硬件——ARM
arm开发
wdfk_prog3 天前
[Linux]学习笔记系列 -- [arm][lib]
linux·运维·arm开发·笔记·学习
努力自学的小夏3 天前
RK3568 Linux驱动学习——新字符设备驱动
linux·arm开发·驱动开发·笔记·学习
wdfk_prog5 天前
[Linux]学习笔记系列 -- [arm][lds]
linux·运维·arm开发·笔记·学习
szxinmai主板定制专家5 天前
基于FPGA的热电偶测温数据采集系统,替代NI的产品(二)总体设计方案
arm开发·人工智能·嵌入式硬件·fpga开发
cici158746 天前
ARM保留的标准中断处理程序入口和外设中断处理程序入口介绍
arm开发
学不动CV了7 天前
FreeRTOS入门知识(初识RTOS任务调度)(三)
c语言·arm开发·stm32·单片机·物联网·算法·51单片机
程序员JerrySUN7 天前
四级页表通俗讲解与实践(以 64 位 ARM Cortex-A 为例)
java·arm开发·数据库·redis·嵌入式硬件·缓存
zhmc8 天前
MCU程序的ARM-GCC编译链接
arm开发·单片机·嵌入式硬件