DIY编程器网

 找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1262|回复: 0
打印 上一主题 下一主题

[待整理] 乘法指令之:MUL乘法指令

[复制链接]
跳转到指定楼层
楼主
发表于 2014-10-10 07:29:11 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
ARM乘法指令完成两个数据的乘法。两个32位二进制数相乘的结果是64位的积。在有些ARM的处理器版本中,将乘积的结果保存到两个独立的寄存器中。另外一些版本只将最低有效32位存放到一个寄存器中。
         
        无论是哪种版本的处理器,都有乘-累加的变型指令,将乘积连续累加得到总和。而且有符号数和无符号数都能使用。对于有符号数和无符号数,结果的最低有效位是一样的。因此,对于只保留32位结果的乘法指令,不需要区分有符号数和无符号数两种情况。
        乘法指令的二进制编码格式如图7.1所示。
       

        图7.1  乘法指令的二进制编码

         
        表7.1显示了各种形式乘法指令的功能。
        表7.1 各种形式乘法指令
                                                                        操作码[23:21]
                       
                                                                        助记符
                       
                                                                        意    义
                       
                                                                        操    作
                       
                                                                        000
                       
                                                                        MUL
                       
                                                                        乘(保留32位结果)
                       
                                                                        Rd:=(Rm×Rs)[31∶0]
                       
                                                                        001
                       
                                                                        MLA
                       
                                                                        乘-累加(32位结果)
                       
                                                                        Rd:=(Rm×Rs+Rn)[31∶0]
                       
                                                                        100
                       
                                                                        UMULL
                       
                                                                        无符号数长乘
                       
                                                                        RdHi:RdLo:=Rm×Rs
                       
                                                                        101
                       
                                                                        UMLAL
                       
                                                                        无符号长乘-累加
                       
                                                                        RdHi:RdLo:+=Rm×Rs
                       
                                                                        110
                       
                                                                        SMULL
                       
                                                                        有符号数长乘
                       
                                                                        RdHi:RdLo:=Rm×Rs
                       
                                                                        111
                       
                                                                        SMLAL
                       
                                                                        有符号数长乘-累加
                       
                                                                        RdHi:RdLo:+=Rm×Rs
                       
         
        其中:
        ① “RdHi:RdLo”是由RdHi(最高有效32位)和RdLo(最低有效32位)链接形成的64位数,“[31:0]”只选取结果的最低有效32位。
         
        ② 简单的赋值由“:=”表示。
         
        ③ 累加(将右边加到左边)是由“+=”表示。
         
        同其他数据处理指令一样,位S控制条件码的设置。当在指令中设置了位S时,则有以下结果。
         
        ① 对于产生32位结果的指令形式,将标志位N设置为Rd的第31位的值;对于产生长结果的指令形式,将其设置为RdHi的第31位的值。
         
        ② 对于产生32位结果的指令形式,如果Rd等于零,则标志位Z置位;对于产生长结果的指令形式,RdHi和RdLo同时为零时,标志位Z置位。
         
        ③ 将标志位C设置成无意义的值。
         
        ④ 标志位V不变。
         
                                                                         
                       
                                                                        注意
                       
                                                                        乘法指令不能对第二操作数使用立即数或被移位的寄存器。
                       
         

        7.1  MUL乘法指令

         
        1.指令编码格式

        MUL(Multiply)32位乘法指令将Rm和Rs中的值相乘,结果的最低32位保存到Rd中。
        指令的编码格式如图7.2所示。
       

        图7.2  MUL指令的编码格式

         
        2.指令的语法格式

        MUL{<cond>}{S}   <Rd>,<Rm>,<Rs>
         
        ① <cond>
        为指令编码中的条件域。它指示指令在什么条件下执行。当<cond>忽略时,指令为无条件执行(cond=AL(Alway))。
         
        ② S
        S位(bit[20])决定指令的操作是否影响CPSR中的条件标志位N位和Z位的值。当S=1时,更新CPSR中的条件标志位的值;当S=0时,指令不更新CPSR中的条件标志位。
         
        ③ <Rd>
        寄存器位目标寄存器。
         
        ④ <Rm>
        第一个乘数所在寄存器。
         
        ⑤ <Rs>
        第二乘数所在寄存器。
         
        3.指令操作的伪代码

        指令操作的伪代码如下面程序段所示。
         
        If  ConditionPassed{cond}  then
             Rd={Rm*Rs}[31:0]
             If  S==1  then
                  N  flag = Rd[31]
                  Z  flag = if  Rd==0  then  1  else  0
                  C  flag = unaffected
                  V  flag = unaffected
         
                                                                         
                       
                                                                        注意
                       
                                                                        当程序计数器r15被用作<Rd>、<Rm>、<Rs>时,指令的执行结果不可预知;当目的寄存器<Rd>和<Rm>一样时,指令的执行结果不可预知;在ARM版本v5以后的体系中,在MULS指令执行结束后,标志位C保持不变,在v5以前的版本中,MULS指令执行后,标志位C结果不可预知。
                       
        4.指令举例

        (1)R1=R2×R3
         
        MUL    R1, R2, R3
         
        (2)R0=R3×R7,同时设置CPSR中N位和Z位。
         
        MULS    R0, R3, R7
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|文字版|手机版|DIY编程器网 ( 桂ICP备14005565号-1 )

GMT+8, 2024-12-27 13:14 , 耗时 0.112398 秒, 21 个查询请求 , Gzip 开启.

各位嘉宾言论仅代表个人观点,非属DIY编程器网立场。

桂公网安备 45031202000115号

DIY编程器群(超员):41210778 DIY编程器

DIY编程器群1(满员):3044634 DIY编程器1

diy编程器群2:551025008 diy编程器群2

QQ:28000622;Email:libyoufer@sina.com

本站由桂林市临桂区技兴电子商务经营部独家赞助。旨在技术交流,请自觉遵守国家法律法规,一旦发现将做封号删号处理。

快速回复 返回顶部 返回列表