=============================
汇编言语每行的语法:
lable: instruction ; comment
段操作: .section
格局: .section 段名 [标志]
[标志]可所以如下:
a 答应段
w 可写段
x 可执行段
常见段名: data, bss, text, rodata段,咱们也能够界说咱们自己的段。
.data: 已初始化数据段
.bss: 未初始化数据段
.text:代码段
.rodata:只读段
汇编程序的进口点:
一般,linux的汇编程序的进口点都是从_start这个大局符号开端的。而C言语的进口点是main, main函数便是被_start后边的代码调用。
.global _start
_start:
代码,,,初始化程序运转环境;
代码,,,
,,,
bl main
bl exit
linux汇编中常数的运用:
十进制: 以非0 的数字最初一共, 124, 564
二进制: 以0b最初,如0b101001
八进制: 以0开端的数字,如05645
十六进制:以0x最初, 如0xab12
linux汇编中常用的伪操作:
数据界说伪操作:
.byte, 界说单个字节, 如, .byte 5, 4, 0b1001, 0x22, 055, b
.short, 界说半字数据, 如,.short 0x1122, 3344
.long, 界说4字节数据,如, 0x11223344,
.word
.string, .asciz, .ascii, 界说字符串数据, 比方.string “hello”
对齐伪操作: .align n –> 2^n
文件完毕操作:.end
文件包括操作:.include, 一般是在文件最初的时分包括头文件时运用
代码指令集切换:
.thumb, .code 16 这两个伪指令告知编译器从这儿开端,今后的代码都编译成16为的thumb指令。
.arm, .code 32 这两个伪指令告知编译器从这儿开端,今后的代码都编译成32为的arm指令。
函数界说格局:
函数名:
函数体
函数回来查办
比方add函数:
.global add
add:
add r0, r1, r2
mov pc, lr
常见符号的含义和用法:
@ : 代码注释符号
; 查办别离符号。(相当于C言语中的;)
# 当即数前缀