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

相关推荐
TeYiToKu3 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
w微信1501350781220 小时前
小华一级 代理商 HC32F005C6PA-TSSOP20 HC32F005系列
c语言·arm开发·单片机·嵌入式硬件
憧憬一下21 小时前
Pinctrl子系统中Pincontroller和client驱动程序的编写
arm开发·嵌入式·c/c++·linux驱动开发
上海知从科技1 天前
知从科技受邀出席ARM日产技术日
arm开发·科技
极客小张2 天前
基于STM32的智能温室环境监测与控制系统设计(代码示例)
c语言·arm开发·stm32·单片机·嵌入式硬件·物联网·毕业设计
TeYiToKu3 天前
笔记整理—linux驱动开发部分(6)platform平台总线
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件
飞腾开发者3 天前
飞腾平台Arm ComputeLibrary编译安装指南
linux·服务器·arm开发·后端·性能优化
CodingCos3 天前
【ARM Linux 系统稳定性分析入门及渐进 1.1 -- Crash 工具功能概述】
linux·arm开发·crash tools·linux crash·crash 工具使用
@haihi5 天前
IIC和SPI的区别和相同之处
arm开发·stm32·mcu
@@庆5 天前
FreeRTOS 数据传输方法(环形buffer,队列的本质)队列实验—多设备玩游戏
arm开发·stm32·单片机·嵌入式硬件·freertos