为什么需要多寄存器访问指令?
- ldr/str每周期只能访问4字节内存,如果需要批量读取、写入内存时太慢,解决方案是stm/ld
举例(uboot start.S 537行) stmia sp, {r0 - r12}
- 将r0存入sp指向的内存处(假设为0x30001000);然后地址+4(即指向0x30001004),将r1存入该地址;然后地址再+4(指向 0x30001008),将 r2存入该地址······直到r12内容放入(0x3000130),指令完成。
- 一个访存周期同时完成13个寄存器的读写
8种后缀