乘法指令之:MUL乘法指令
2.指令的语法格式
MUL{cond>}{S}Rd>,Rm>,Rs>
①cond>
为指令编码中的条件域。它指示指令在什么条件下执行。当cond>忽略时,指令为无条件执行(cond=AL(Alway))。
②S
S位(bit[20])决定指令的操作是否影响CPSR中的条件标志位N位和Z位的值。当S=1时,更新CPSR中的条件标志位的值;当S=0时,指令不更新CPSR中的条件标志位。
③Rd>
寄存器位目标寄存器。
④Rm>
第一个乘数所在寄存器。
⑤Rs>
第二乘数所在寄存器。
3.指令操作的伪代码
指令操作的伪代码如下面程序段所示。
IfConditionPassed{cond}then
Rd={Rm*Rs}[31:0]
IfS==1then
Nflag=Rd[31]
Zflag=ifRd==0then1else0
Cflag=unaffected
Vflag=unaffected
注意 | 当程序计数器r15被用作Rd>、Rm>、Rs>时,指令的执行结果不可预知;当目的寄存器Rd>和Rm>一样时,指令的执行结果不可预知;在ARM版本v5以后的体系中,在MULS指令执行结束后,标志位C保持不变,在v5以前的版本中,MULS指令执行后,标志位C结果不可预知。 |
4.指令举例
(1)R1=R2×R3
MULR1,R2,R3
(2)R0=R3×R7,同时设置CPSR中N位和Z位。
MULSR0,R3,R7
评论