文章目录
-
- [.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 标志位的学习