【ARMv8/v9 常见汇编指令学习 6.1 - armv8 右移指令 LSR 详细介绍】


请阅读【嵌入式开发学习必备专栏 】


文章目录

armv8 右移指令 LSR

在ARMv8架构中,lsr(Logical Shift Right)指令是一种逻辑右移指令,用于将一个寄存器中的数值向右移动指定的位数。逻辑右移操作会从左侧填充0,这与算术右移(asr,Arithmetic Shift Right)不同,后者会根据符号位填充。lsr指令在进行位操作、快速除法运算(对2的幂次进行除法)或处理位字段时非常有用。

语法

lsr指令的基本语法如下:

lsr <Xd>, <Xn>, #<imm>
  • <Xd>:目的寄存器,存储操作结果。
  • <Xn>:源寄存器,其内容将被右移。
  • #<imm>:立即数,指定右移的位数。

示例

假设我们希望将寄存器X1中的值向右移动2位,并将结果存储到寄存器X0中,可以这样写:

lsr X0, X1, #2

如果X1的内容是0b111100(十进制中的60),执行上述lsr指令后,X0中的内容将是0b1111(十进制中的15)。

注意事项

  • 在使用lsr指令时,需要注意移位数#<imm>的合法范围。对于32位寄存器(W系列),移位数的范围是0到31;对于64位寄存器(X系列),移位数的范围是0到63。
  • 移位操作不仅可以实现快速的乘除法计算(针对2的幂次),还可以用于清理特定的位、设置位字段或者在位层面上操作数据。
  • lsr指令与算术右移指令asr的主要区别在于填充位的处理。lsr总是用0填充空出的位,而asr则根据原数的符号位填充,这在处理带符号整数时非常重要。
    总的来说,lsr是ARMv8指令集中处理位操作的基本指令之一,适用于各种需要逻辑右移操作的场景。