ARM匯編指令集之五——乘法指令與乘加指令
乘法指令與乘加指令共有以下6條:
本文引用地址:http://cafeforensic.com/article/201611/317601.htm1、 MUL指令
MUL指令的格式為:
MUL{條件}{S}目的寄存器,操作數(shù)1,操作數(shù)2
MUL指令完成將操作數(shù)1與操作數(shù)2的乘法運算,并把結(jié)果放置到目的寄存器中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號數(shù)或無符號數(shù)。
指令示例:
MUL R0,R1,R2;R0 = R1×R2
MULS R0,R1,R2;R0 = R1×R2,同時設(shè)置CPSR中的相關(guān)條件標志位
2、 MLA指令
MLA指令的格式為:
MLA{條件}{S}目的寄存器,操作數(shù)1,操作數(shù)2,操作數(shù)3
MLA指令完成將操作數(shù)1與操作數(shù)2的乘法運算,再將乘積加上操作數(shù)3,并把結(jié)果放置到目的寄存器中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號數(shù)或無符號數(shù)。
指令示例:
MLA R0,R1,R2,R3;R0 = R1×R2 + R3
MLAS R0×R2 + R3,同時設(shè)置CPSR中的相關(guān)條件標志位3、 SMULL指令
SMULL指令的格式為:
SMULL{條件}{S}目的寄存器Low,目的寄存器低High,操作數(shù)1,操作數(shù)2
SMULL指令完成將操作數(shù)1與操作數(shù)2的乘法運算,并把結(jié)果的低32位放置到目的寄存器Low中,結(jié)果的高32位放置到目的寄存器High中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號數(shù)。
指令示例:
SMULL R0,R1,R2,R3;R0 =(R2×R3)的低32位
;R1 =(R2×R3)的高32位
4、 SMLAL指令
SMLAL指令的格式為:
SMLAL{條件}{S}目的寄存器Low,目的寄存器低High,操作數(shù)1,操作數(shù)2
SMLAL指令完成將操作數(shù)1與操作數(shù)2的乘法運算,并把結(jié)果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,結(jié)果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號數(shù)。
對于目的寄存器Low,在指令執(zhí)行前存放64位加數(shù)的低32位,指令執(zhí)行后存放結(jié)果的低32位。
對于目的寄存器High,在指令執(zhí)行前存放64位加數(shù)的高32位,指令執(zhí)行后存放結(jié)果的高32位。
指令示例:
SMLAL R0,R1,R2,R3;R0 =(R2×R3)的低32位+R0
;R1 =(R2×R3)的高32位+R1
5、 UMULL指令
UMULL指令的格式為:
UMULL{條件}{S}目的寄存器Low,目的寄存器低High,操作數(shù)1,操作數(shù)2
UMULL指令完成將操作數(shù)1與操作數(shù)2的乘法運算,并把結(jié)果的低32位放置到目的寄存器Low中,結(jié)果的高32位放置到目的寄存器High中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的無符號數(shù)。
指令示例:
UMULL R0,R1,R2,R3;R0 =(R2×R3)的低32位
;R1 =(R2×R3)的高32位
6、 UMLAL指令
UMLAL指令的格式為:
UMLAL{條件}{S}目的寄存器Low,目的寄存器低High,操作數(shù)1,操作數(shù)2
UMLAL指令完成將操作數(shù)1與操作數(shù)2的乘法運算,并把結(jié)果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,結(jié)果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同時可以根據(jù)運算結(jié)果設(shè)置CPSR中相應(yīng)的條件標志位。其中,操作數(shù)1和操作數(shù)2均為32位的無符號數(shù)。
對于目的寄存器Low,在指令執(zhí)行前存放64位加數(shù)的低32位,指令執(zhí)行后存放結(jié)果的低32位。
對于目的寄存器High,在指令執(zhí)行前存放64位加數(shù)的高32位,指令執(zhí)行后存放結(jié)果的高32位。
指令示例:
UMLAL R0,R1,R2,R3 ;R0 =(R2×R3)的低32位+R0
;R1 =(R2×R3)的高32位+R1
評論