汇编语言
GNU汇编语法
汇编指令格式:
label:instruction @comment
- label:标号
- instruction:指令:汇编指令或伪指令
- @comment:注释,comment注释内容
伪操作
.text 表示代码段。
.data 初始化的数据段。
.bss 未初始化的数据段。
.rodata 只读数据段。
.byte 定义单字节数据,比如.byte 0x12。
.short 定义双字节数据,比如.short 0x1234。
.word 定义双字节数据,比如.word number。
.long 定义一个 4 字节数据,比如.long 0x12345678。
.equ 赋值语句,格式为:.equ 变量名,表达式,比如.equ num, 0x12,表示 num=0x12。
.align 数据字节对齐,比如:.align 4 表示 4 字节对齐。
.end 表示源文件结束。
.global 定义一个全局符号,格式为:.global symbol,比如:.global _start。
声明全局变量
- .global start 声明全局变量
声明全局变量
- ENTRY(save_boot_params)
#define ENTRY(name) \
.globl SYMBOL_NAME(name) ASM_NL \
LENTRY(name)
- ENDPROC(save_boot_params)
#define ENDPROC(name) \
.type name STT_FUNC ASM_NL \
END(name)
处理器内部数据传输指令
MOV R0, R1 ----------------等价于---------------将R1里面的数据复制到 R0 中。
MRS R0, CPSR ----------------等价于---------------将特殊寄存器 CPSR 里面的数据复制到 R0 中。
MSR CPSR, R1 ----------------等价于---------------将 R1 里面的数据复制到特殊寄存器 CPSR 里中。
内存与存储器访问指令
LDR Rd, [Rn, #offset] ----------------等价于---------------从存储器 Rn+offset 的位置读取数据存放到 Rd 中。
STR Rd, [Rn, #offset] ----------------等价于---------------将 Rd 中的数据写入到存储器中的 Rn+offset 位置。
压栈和出栈指令
PUSH <reg list> ----------------等价于---------------将寄存器列表存入栈中。
POP <reg list> ----------------等价于---------------从栈中恢复寄存器列表。
跳转指令
b 无返回跳转
bl 有返回跳转
算数运算指令
1.加法ADD
ADD Rd, Rn, Rm ----------------等价于---------------Rd = Rn + Rm
ADD Rd, Rn, #immed ----------------等价于---------------Rd = Rn + #immed
1.1带进位的加法运算,指令为 ADC
ADC Rd, Rn, Rm ----------------等价于---------------Rd = Rn + Rm + 进位
ADC Rd, Rn, #immed ----------------等价于---------------Rd = Rn + #immed +进位
2.减法SUB
SUB Rd, Rn, Rm ----------------等价于---------------Rd = Rn – Rm
SUB Rd, #immed ----------------等价于---------------Rd = Rd - #immed
SUB Rd, Rn, #immed ----------------等价于---------------Rd = Rn - #immed
3.带借位的减法SBC
SBC Rd, Rn, #immed ----------------等价于---------------Rd = Rn - #immed – 借位
SBC Rd, Rn ,Rm ----------------等价于---------------Rd = Rn – Rm – 借位
4.乘法MUL
MUL Rd, Rn, Rm ----------------等价于---------------Rd = Rn * Rm 乘法(32 位)
5.除法UDIV和SDIV
UDIV Rd, Rn, Rm ----------------等价于---------------Rd = Rn / Rm 无符号除法
SDIV Rd, Rn, Rm ----------------等价于---------------Rd = Rn / Rm 有符号除法
逻辑运算指令
按位与
AND Rd, Rn ----------------等价于--------------- Rd = Rd &Rn
AND Rd, Rn, #immed ----------------等价于--------------- Rd = Rn &#immed
AND Rd, Rn, Rm ----------------等价于--------------- Rd = Rn & Rm
按位或
ORR Rd, Rn ----------------等价于---------------Rd = Rd | Rn
ORR Rd, Rn, #immed ----------------等价于---------------Rd = Rn | #immed
ORR Rd, Rn, Rm ----------------等价于---------------Rd = Rn | Rm
位清除
BIC Rd, Rn ----------------等价于---------------Rd = Rd & (~Rn)
BIC Rd, Rn, #immed ----------------等价于---------------Rd = Rn & (~#immed)
BIC Rd, Rn , Rm ----------------等价于---------------Rd = Rn & (~Rm)
按位或非
ORN Rd, Rn, #immed ----------------等价于---------------Rd = Rn | (#immed)
ORN Rd, Rn, Rm ----------------等价于---------------Rd = Rn | (Rm)
按位异或
EOR Rd, Rn ----------------等价于---------------Rd = Rd ^ Rn
EOR Rd, Rn, #immed ----------------等价于---------------Rd = Rn ^ #immed
EOR Rd, Rn, Rm ----------------等价于---------------Rd = Rn ^ Rm