新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 乘法指令之: MLA乘-累加指令

        乘法指令之: MLA乘-累加指令

        作者: 時間:2013-09-13 來源:網絡 收藏

        7.2指令

        1.指令編碼格式

        (MultiplyAccumulate)32位乘累加指令將Rm和Rs中的值相乘,再將乘積加上第3個操作數,結果的最低32位保存到Rd中。

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

        指令的編碼格式如圖7.3所示。

        圖7.3指令的編碼格式

        2.指令的語法格式

        MLA{cond>}{S}Rd>,Rm>,Rs>,Rn>

        ①cond>

        為指令編碼中的條件域。它指示指令在什么條件下執行。當cond>忽略時,指令為無條件執行(cond=AL(Alway))。

        ②S

        S位(bit[20])決定指令的操作是否影響CPSR中的條件標志位N位和Z位的值。當S=1時,更新CPSR中的條件標志位的值;當S=0時,指令不更新CPSR中的條件標志位。

        ③Rd>

        寄存器位目標寄存器。

        ④Rm>

        第一個乘數所在寄存器。

        ⑤Rs>

        第二乘數所在寄存器。

        ⑥Rn>

        將要累加到Rm>×Rs>結果中的第3操作數。

        3.指令操作的偽代碼

        指令操作的偽代碼如下面程序段所示。

        IfConditionPassed{cond}then

        Rd={Rm*Rs+Rn}[31:0]

        IfS==1then

        Nflag=Rd[31]

        Zflag=ifRd==0then1else0

        Cflag=unaffected

        Vflag=unaffected

        4.指令舉例

        下面指令完成R1=R2×R3+10的操作。

        MOVR0,#0x0A;

        MLAR1,R2,R3,R0;



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 正定县| 武强县| 元江| 河北省| 称多县| 达州市| 通城县| 枝江市| 双牌县| 威信县| 德阳市| 六枝特区| 太白县| 新丰县| 柳江县| 宜昌市| 永和县| 大余县| 南宫市| 镇赉县| 定陶县| 昌图县| 宁德市| 武夷山市| 个旧市| 荥经县| 宣化县| 定边县| 仁化县| 寻甸| 莲花县| 阿克陶县| 黔西| 固阳县| 安龙县| 佳木斯市| 万源市| 库车县| 辽中县| 南安市| 顺昌县|