ARM 汇编语言编程:寄存器操作与程序构建
1. 寄存器与移位操作
在 ARM 汇编中,我们可以指定寄存器和移位操作。具体来说,指定一个 4 位的寄存器和一个 5 位的移位值(总共实现 32 位的移位)。例如:
MOV R1, R2, LSL #1 @ 逻辑左移
这表示将 R2 中的值逻辑左移 1 位,并将结果存入 R1。还有其他的移位和旋转操作:
MOV R1, R2, LSR #1 @ 逻辑右移
MOV R1, R2, ASR #1 @ 算术右移
MOV R1, R2, ROR #1 @ 循环右移
MOV R1, R2, RRX @ 扩展循环右移
由于移位和旋转操作很常见,汇编器提供了助记符,例如:
LSL R1, R2, #1 @ 逻辑左移
LSR R1, R2, #1 @ 逻辑右移
ASR R1, R2, #1 @ 算术右移
ROR R1, R2, #1 @ 循环右移
RRX R1, R2 @ 扩展循环右移
这些助记符生成的字节码与前面的 MOV 指令相同,目的是让代码更易读。
2. 小数字与旋转
操作数 2 的另一种形式是小数字,即一个 8 位(1 字节)的量,可以通过偶数位进行
超级会员免费看
订阅专栏 解锁全文

47

被折叠的 条评论
为什么被折叠?



