新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM匯編指令集之五——乘法指令與乘加指令

        ARM匯編指令集之五——乘法指令與乘加指令

        作者: 時(shí)間:2016-11-09 來源:網(wǎng)絡(luò) 收藏
        ARM微處理器支持的乘法指令乘加指令共有6條,可分為運(yùn)算結(jié)果為32位和運(yùn)算結(jié)果為64位兩類,與前面的數(shù)據(jù)處理指令不同,指令中的所有操作數(shù)、目的寄存器必須為通用寄存器,不能對(duì)操作數(shù)使用立即數(shù)或被移位的寄存器,同時(shí),目的寄存器和操作數(shù)1必須是不同的寄存器。

        乘法指令與乘加指令共有以下6條:

        本文引用地址:http://www.104case.com/article/201611/317601.htm

        1、 MUL指令

        MUL指令的格式為:

        MUL{條件}{S}目的寄存器,操作數(shù)1,操作數(shù)2

        MUL指令完成將操作數(shù)1與操作數(shù)2的乘法運(yùn)算,并把結(jié)果放置到目的寄存器中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號(hào)數(shù)或無符號(hào)數(shù)。

        指令示例:

        MUL R0,R1,R2;R0 = R1×R2

        MULS R0,R1,R2;R0 = R1×R2,同時(shí)設(shè)置CPSR中的相關(guān)條件標(biāo)志位

        2、 MLA指令

        MLA指令的格式為:

        MLA{條件}{S}目的寄存器,操作數(shù)1,操作數(shù)2,操作數(shù)3

        MLA指令完成將操作數(shù)1與操作數(shù)2的乘法運(yùn)算,再將乘積加上操作數(shù)3,并把結(jié)果放置到目的寄存器中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號(hào)數(shù)或無符號(hào)數(shù)。

        指令示例:

        MLA R0,R1,R2,R3;R0 = R1×R2 + R3

        MLAS R0×R2 + R3,同時(shí)設(shè)置CPSR中的相關(guān)條件標(biāo)志位

        3、 SMULL指令

        SMULL指令的格式為:

        SMULL{條件}{S}目的寄存器Low,目的寄存器低High,操作數(shù)1,操作數(shù)2

        SMULL指令完成將操作數(shù)1與操作數(shù)2的乘法運(yùn)算,并把結(jié)果的低32位放置到目的寄存器Low中,結(jié)果的高32位放置到目的寄存器High中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號(hào)數(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的乘法運(yùn)算,并把結(jié)果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,結(jié)果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的有符號(hào)數(shù)。

        對(duì)于目的寄存器Low,在指令執(zhí)行前存放64位加數(shù)的低32位,指令執(zhí)行后存放結(jié)果的低32位。

        對(duì)于目的寄存器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的乘法運(yùn)算,并把結(jié)果的低32位放置到目的寄存器Low中,結(jié)果的高32位放置到目的寄存器High中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的無符號(hào)數(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的乘法運(yùn)算,并把結(jié)果的低32位同目的寄存器Low中的值相加后又放置到目的寄存器Low中,結(jié)果的高32位同目的寄存器High中的值相加后又放置到目的寄存器High中,同時(shí)可以根據(jù)運(yùn)算結(jié)果設(shè)置CPSR中相應(yīng)的條件標(biāo)志位。其中,操作數(shù)1和操作數(shù)2均為32位的無符號(hào)數(shù)。

        對(duì)于目的寄存器Low,在指令執(zhí)行前存放64位加數(shù)的低32位,指令執(zhí)行后存放結(jié)果的低32位。

        對(duì)于目的寄存器High,在指令執(zhí)行前存放64位加數(shù)的高32位,指令執(zhí)行后存放結(jié)果的高32位。

        指令示例:

        UMLAL R0,R1,R2,R3 ;R0 =(R2×R3)的低32位+R0

        ;R1 =(R2×R3)的高32位+R1




        評(píng)論


        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 图们市| 如东县| 林周县| 西和县| 呼和浩特市| 丹江口市| 新蔡县| 颍上县| 商城县| 开阳县| 衡山县| 盐津县| 兴义市| 沐川县| 富顺县| 宜昌市| 吉安市| 西乌珠穆沁旗| 中阳县| 新巴尔虎左旗| 阿巴嘎旗| 赞皇县| 琼中| 盐津县| 成武县| 邢台市| 德庆县| 丽水市| 墨江| 醴陵市| 黄大仙区| 梁平县| 新民市| 芦山县| 霸州市| 延吉市| 罗源县| 耒阳市| 华坪县| 广安市| 雷州市|