ARM汇编LSLS指令

CM3处理器支持Thumb和ARM指令集,LSL指令用于逻辑左移操作。该指令根据立即数移动寄存器位,LSLS还会更新条件标志中的C位。例如,指令LSLSR1,R1,#5将R1寄存器左移5位,若原值为0x80000000,则结果为0,C位清零;若原值为0x08000000,则结果溢出,C位置位。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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置位.

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值