CM3中兼容thumb和ARM指令,为thumb指令(16位)和ARM指令(32位),在CM3中汇编中常用到LSL指令,此指令用于逻辑左移
逻辑左移(立即数)将寄存器值左移一个立即位数,并将结果写入目标寄存器。它可以根据结果选择性地更新条件标志,即是LSL和LSLS的区别,LSLS会根据移位结果更新xPSR中的C位。
指令代码为:LSLS <Rd>,<Rm>,#<imm5>
其中 Rd:表示目标寄存器,计算结果最后写入的地方
Rm:表示即将操作的寄存器,进入ALU的原始数据
imm5:此数据表示要左移几位,最多31位
下表是从CM3-权威指南中摘抄来的,详细更多可参考CM3-权威指南:
举例说明:
在“LSLS R1,R1,#5”这句汇编代码中,意思是将R1寄存器左移 5 位再写回到R1寄存器中。
如果 R1 = 0x8000 0000,执行完上面指令后 R1= 0, xPSR中C为0;
如果 R1 = 0x0800 0000,执行完上面指令后 R1= 0, xPSR中C为1;
第二种情况下,因为左移5位后,R1= 0x1 0000 0000,导致溢出的那以为正好是1,所以C置位.