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

相关推荐
与遨游于天地7 小时前
从 BPF 到 eBPF:一场 Linux 内核的“可编程”革命
linux·运维·arm开发
Chuncheng's blog8 小时前
Ubuntu 24.04 ISO国内镜像下载(ARM / AMD64)
arm开发·ubuntu
忆和熙1 天前
ARMv8异常的类型与处理
arm开发·arm异常
EnglishJun1 天前
ARM嵌入式学习(二) --- 入门51(中断)
arm开发·学习
头发够用的程序员2 天前
GPU 流水线底层探索:从 SIMT 前端到 SIMD 后端的全链路解析
arm开发·人工智能·嵌入式硬件·深度学习·硬件架构·边缘计算
梁洪飞2 天前
armv7a和uboot里面的重要概念
arm开发·嵌入式硬件·arm
忆和熙3 天前
ARM异常概述与级别(ARMv8异常机制——异常的概述、级别)
arm开发·arm异常
嵌入式学习菌3 天前
用 mDNS 实现逆变器与电表的自动通信
arm开发
fygfh.3 天前
Linux的系统架构浅析
linux·arm开发·系统架构
忆和熙4 天前
ARM Load/Store指令、伪指令(ARM处理器指令系统——ARM指令集初学,下篇)
arm开发·arm指令