【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 标志位的学习

相关推荐
Q_21932764552 小时前
基于ARM的嵌入式温度控制系统的设计
arm开发
想你依然心痛7 小时前
从x86到ARM的HPC之旅:鲲鹏开发工具链(编译器+数学库+MPI)上手与实战
java·开发语言·arm开发·鲲鹏·昇腾
MUTA️7 小时前
x86 架构下运行 ARM-ROS2 Docker 镜像操作指南
arm开发·docker·架构
比奇堡派星星1 天前
Linux 杂项设备驱动框架详解
linux·arm开发·驱动开发
xingzhemengyou11 天前
LINUX 通过/proc/interrupts了解系统硬件中断的使用情况
linux·arm开发
rfidunion1 天前
ubuntu下使用qemu模拟ARM(一)-------安装samba服务器
服务器·arm开发·ubuntu
三佛科技-134163842121 天前
FT32F072xx、FT32F072xB、FT32F072x6/x8基于ARM Cortex-M0内核32位单片机分析
arm开发·单片机·嵌入式硬件·智能家居·pcb工艺
p66666666681 天前
STM32(基于 ARM Cortex-M 内核)中函数调用栈帧的开辟 销毁过程
arm开发·stm32·嵌入式硬件
星空真迷人2 天前
嵌入式 WiFi 加持 普通设备也能联网 “唠嗑”
arm开发·stm32·单片机·嵌入式硬件·物联网·iot
灵哎惹,凌沃敏3 天前
FreeRTOS 任务上下文切换核心函数:xPortPendSVHandler详解
c语言·arm开发