伪指令:没有二进制对应的指令,编译时会分解为多条真正指令,当一个标记前有=是,表明它是一个伪指令,比如mov r1,=1234567;这条指令中的立即数不是合法的立即数,因此前边必须加上=,编译器将把它分解成多条指令。
标号代表地址。
标号分为段内标号和段外标号。段内标号的地址值在汇编时确定,段外编号的地址值在链接时确定 。
在程序段中,标号代表其所在位置与段首地址的偏移量。根据程序计数器(PC)和偏移量计算地址即程序相对寻址。
在映像中定义的标号代表标号到映像首地址的偏移量。映像的首地址通常被赋予一个寄存器,根据该寄存器值与偏移量计算地址即寄存器相对寻址。
局部标号是0~99的十进位数开始,可以重复定义。
局部标号引用格式:
%{F|B}{A|T} N{routname}
% :局部标号引用操作。
F :编译器只向前搜索。
B :编译器只向后搜索。
A :编译器搜索宏的所有嵌套层次。
T :编译器搜索宏的当前层。
ENTRY(xxx):一个程序
一个程序可以有多个entry,但真正的入口点由连接器指定,但一个源文件只能有一个entry.
b label:跳转
bl label:跳转并保存下一条指令地址到lr中,两者都是小范围跳转(+_32M)
adr r1,label:小范围地址读取指令(+_1M),相对于pc,执行时会执行加减法代替。根据代码的存储位置不同而不同。
adrl r1,label:中范围地址读取指令(+_256M)
ldr r1,=label:大范围地址读取指令,绝对地址,连接时确定,执行时相当于立即数。无论拷到哪,都是连接时的地址。
mov:赋值 mov r1,r2 r1=r2; mov r1, #4096; 如果能用立即数表示则用mov,否则编译器将用ldr:ldr r1,=4096
ldr r1,label:代表把label地址处的数据读出来。
ldr r1,=label:的编译结果是:label的下32位空出来用来存放label代表的地址,然后执行ldr r1,[pc,label-pc+4],结果就是r1=[label+4],而label+4正好存放的是label的绝对地址,因此,r1的值就是连接时label的绝对地址,这段代码放到哪个地方,这个值永远不变。
ldm:批量内存访问:stmdb sp!,{r0-r12,lr}:stm表示把寄存器中的值保存到内存中,db表示事先递减,!表示sp会更新为sp=sp-14*4.
msr,mrs:操作程序状态寄存器;
.align 4表示通过填充字节使自己的地址是4的倍数
.extern main定义一个外部符号,表示该符号不是第一次出现。
.text 以下语句属于代码段
.global本程序标号是全局的
.macro..... .endm定义一个宏
ATPCS规定数据栈是FD(满递减,8字节对齐):sp指针指向栈顶元素,向低地址方向递增。<---