新聞中心

        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;



        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 察雅县| 开江县| 安陆市| 孝感市| 黔西| 民勤县| 廉江市| 滦平县| 通榆县| 塔河县| 新安县| 沂源县| 汉阴县| 边坝县| 万山特区| 措美县| 西畴县| 中江县| 柳江县| 平和县| 卓资县| 屏东市| 郁南县| 西丰县| 晋中市| 麻栗坡县| 八宿县| 吉水县| 承德县| 石屏县| 五寨县| 贞丰县| 军事| 罗源县| 饶平县| 永善县| 台南县| 斗六市| 友谊县| 全椒县| 蚌埠市|