目录
一、多寄存器内存访问指令
多寄存器内存访问指令:可以将多个寄存器写入内存,或从内存中读取多个寄存器
MOV R1, #1
MOV R2, #2
MOV R3, #3
MOV R4, #4
MOV R11,#0x40000020
STM R11,{R1-R4}
将R1-R4寄存器中的数据写入到以R11为起始地址的内存空间中
LDM R11,{R6-R9}
将以R11为起始地址的内存空间中的数据读取到R6-R9寄存器中
当寄存器编号不连续时,使用逗号分隔
STM R11,{R1,R2,R4}
不管寄存器列表中的顺序如何,存取时永远是低地址对应小编号的寄存器
STM R11,{R3,R1,R4,R2}
自动索引照样适用于多寄存器内存访问指令
STM R11!,{R1-R4}
(1)LDM:L的含义仍然是LOAD(连接寄存器和连续内存的相互copy)
理解为:Load from memory into register。
虽然貌似是LDR的升级,但是,千万要注意,这个指令运行的方向和LDR是不一样的,是从左到右运行的。该指令是将内存中堆栈内的数据,批量的赋值给寄存器,即是出栈操作;其中堆栈指针一般对应于SP,注意SP是寄存器R13,实际用到的却是R13中的内存地址,只是该指令没有写为[R13],同时,LDM指令中寄存器和内存地址的位置相对于前面两条指令改变了,下面的例子:
LDMFD SP! , {R0, R1, R2}
实际上可以理解为: LDMFD [SP]!, {R0, R1, R2}
意思为:把sp指向的3个连续地址段(应该是3*4=12字节(因为为r0,r1,r2都是32位))中的数据拷贝到r0,r1,r2这3个寄存器中去(如果这个地方还不懂的话,可以参看我文章开头提到的链接,里面有详细的图解)
(2)STM:S的含义仍然是STORE,与LDM是配对使用的,其指令格式上也相似,即区别于STR,是将堆栈指针写在左边,而把寄存器组写在右边。
STMFD SP!, {R0}
同样的,该指令也可理解为: STMFD [SP]!, {R0}
意思是:把R0保存到堆栈(sp指向的地址)中。
显然,这两个堆栈操作指令也有个特点,就是寄存器组写在后面(右边)而堆栈指针写在前面(左边),而且实际上使用的是堆栈指针中的内存地址,这一点与前面两条指令是有区别的。
https://blog.youkuaiyun.com/u010164190/article/details/89740770
二、多寄存器内存访问指令的寻址方式
MOV R1, #1
MOV R2, #2
MOV R3, #3
MOV R4, #4
MOV R11,#0x40000020
STMIA R11!,{R1-R4}
先存储数据,后增长地址,Increase after
STMIB R11!,{R1-R4}
先增长地址,后存储数据,Increase before
STMDA R11!,{R1-R4}
先存储数据,后递

文章详细解释了多寄存器内存访问指令的使用、寻址方式,讨论了栈的种类、应用实例,包括叶子函数和非叶子函数的调用过程,以及为何C语言中未初始化的局部变量是随机数。
最低0.47元/天 解锁文章
431





