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

相关推荐
沉在嵌入式的鱼16 小时前
使用nomachine远程连接ARM设备桌面
arm开发·rk3588·远程连接·nomachine
进击的程序汪1 天前
Linux 启动过程流程图--ARM版
linux·运维·arm开发
比奇堡在逃帅哥11 天前
硬件-DAY04(ds18b20、ARM内核)
arm开发
Ronin-Lotus11 天前
微处理器原理与应用篇---ARM常见汇编指令
汇编·arm开发·微处理原理与应用
切糕师学AI11 天前
半导体行业中的专用标准产品ASSP是什么?
arm开发·嵌入式硬件·嵌入式·计算机体系结构
Svan.12 天前
Portable Watch:基于STM32的便携智能手表
arm开发·驱动开发·stm32·嵌入式硬件·硬件工程·pcb工艺·智能手表
凉、介13 天前
CPU Cache 的映射与寻址
linux·arm开发·数据库·redis·缓存·嵌入式
学渣6765613 天前
单片机开发日志cv MDK-ARM工具链迁移到MAKE
arm开发·单片机·嵌入式硬件
ldinvicible13 天前
基于ARM ubuntu如何进行交叉编译
arm开发·数据库·ubuntu
Jason_zhao_MR13 天前
多协议物联网关的方案测试-基于米尔全志T536开发板
arm开发·嵌入式硬件·mcu·物联网·嵌入式