Thumb指令集之:Thumb數(shù)據(jù)處理指令
11.4.25乘法指令MUL
(1)編碼格式
乘法指令MUL的編碼格式如圖11.31所示。
圖11.31MUL指令的編碼格式
MUL指令實現(xiàn)兩個數(shù)(可以為無符號數(shù),也可以為有符號數(shù))的乘積,并將指令的執(zhí)行結(jié)果存放到一個32位的寄存器中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR寄存器中相應(yīng)的條件標(biāo)志位。
(2)指令的語法格式
MULRd>,Rm>
①Rd>
目的寄存器,存放乘法操作的第一個乘數(shù)。
②Rm>
第二個乘數(shù)所在寄存器。
(3)指令操作的偽代碼
Rd=(Rm*Rd)[31:0]
NFlag=Rd[31]
ZFlag=ifRd==0then1else0
CFlag=unaffected
VFlag=unaffected
注意 | 如果乘法指令MUL的源和目的寄存器使用相同的寄存器,則指令的執(zhí)行結(jié)果不可預(yù)知;對于有符號數(shù)和無符號數(shù),指令的操作結(jié)果是一樣的。 |
(4)對應(yīng)的ARM指令
MULSRd>,Rm>,Rd>
11.4.26傳送指令MVN
(1)編碼格式
傳送指令MVN的編碼格式如圖11.32所示。
圖11.32MVN指令的編碼格式
MVN指令將一個數(shù)的反碼傳送到目標(biāo)寄存器,并根據(jù)指令的執(zhí)行結(jié)果更新CPSR中相應(yīng)的條件標(biāo)志位。
(2)指令的語法格式
MVNRd>,Rm>
①Rd>
目的寄存器,存放指令的操作結(jié)果。
②Rm>
源寄存器,存放要傳送反碼的數(shù)據(jù)。
(3)指令操作的偽代碼
Rd=NOTRm
NFlag=Rd[31]
ZFlag=ifRd==0then1else0
CFlag=unaffected
VFlag=unaffected
(4)對應(yīng)的ARM指令
MVNSRd>,Rm>
11.4.27取反指令NEG
(1)編碼格式
取反指令NEG的編碼格式如圖11.33所示。
圖11.33NEG指令的編碼格式
NEG取反指令將一個寄存器的值取反存入另一個寄存器。同時根據(jù)指令的操作結(jié)果更新CPSR中相應(yīng)的條件標(biāo)志位。
(2)指令的語法格式
NEGRd>,Rm>
①Rd>
目的寄存器,存放指令的操作結(jié)果。
②Rm>
源寄存器,包含將要被取反的數(shù)據(jù)。
(3)指令操作的偽代碼
Rd=0–Rm
NFlag=Rd[31]
ZFlag=ifRd==0then1else0
CFlag=NOTBorrowFrom(0-Rm)
VFlag=OverflowFrom(0-Rm)
(4)對應(yīng)的ARM指令
RSBSRd>,Rm>,#0
評論