zoukankan      html  css  js  c++  java
  • ARM学习笔记7——乘法指令

      ARM乘法指令完成两个数据的乘法,两个32位二进制数相乘的结果是64位的4积。

    其中:

      1、“RadHi:RdLo”是由RdHi(最高有效32位)和RdLo(最低有效32位)链接形成的64位数,“[31:0]”只选取结果的最低有效32位

      2、简单的赋值由“:=”表示

      3、累加(将右边加到左边)是由“+=”表示

    一、MUL乘法指令

      1、作用
        将Rm和Rs中的值相乘,结果的最低32位保存到Rd中
      2、语法格式
        MUL{<condition>}{S} <Rd>,<Rm>,<Rs>
      3、参数说明
        3.1、S:S位(bit[20])决定指令的操作是否影响CPSR中的条件标志位N位和Z位的值。当S=1时,跟新CPSR中的条件标志位的值;当S=0,指令不更新CPSR中的条件标志位。
        3.2、<Rd>:寄存器位目标寄存器
        3.3、<Rm>:第一个乘数所在寄存器
        3.4、<Rs>:第二个乘数所在寄存器

      4、举例:

        R1=R2*R3用指令表示为 MUL R1,R2,R3

    二、MLA乘-累加指令
      1、作用
        将Rm和Rs中的值相乘,再将乘积加上第三个操作数,结果的最低32保存到Rd中
      2、语法格式
        MLA{<condition>}{S} <Rd>,<Rm>,<Rs>,<Rn>
      3、参数说明:
        3.1、<Rd>:寄存器位目标寄存器
        3.2、<Rm>:第一个乘数所在寄存器
        3.3、<Rs>:第二个乘数所在寄存器
        3.4、<Rn>:将要累加到<Rm>*<Rs>结果中的第三操作数
      4、举例说明
        R1=R2*R3+10用指令表示为 : 

         MOV  R0,#0x0A
         MLA  R1,R2,R3,R0

    三、UMULL无符号数长乘指令
      1、作用
        UMULL为64位无符号乘法指令,指令将Rm和Rs中的值做无符号数相乘,结果的低32位保存到RsLo中,而高32位保存到RdHi中。
      2、语法格式
        UMULL{<condition>}{S} <RdLo>,<RdHi>,<Rm>,<Rs>
      3、参数说明
        3.1、<RdLo>:寄存器位目标寄存器,存储结果的低32位值
        3.2、<RdHi>:寄存器位目标寄存器,存储结果的高32位值
        3.3、<Rm>:第一个乘数寄存器
        3.4、<Rs>:第二个乘数寄存器
      4、举例
        完成(R1,R0)=R5*R8操作
        UMULL R0,R1,R5,R8

    四、UMLAL无符号长乘-累加操作指令
      1、作用
        UMLAL位64位无符号长乘-累加指令,指令将Rm和Rs中的值做无符号数相乘,64位乘积与RdHi,RdLo相加,结果的低32位保存到RsLo中,而高32位保存到RdHi中。
      2、语法格式
        UMLAL{<condition>}{S} <RdLo>,<RdHi>,<Rm>,<Rs>

      3、举例
        完成(R1,R0)=R5*R8+(R1,R0)操作
        UMLAL R0,R1,R5,R8

    五、SMULL有符号数长乘操作指令
      1、作用
        SMULL64位有符号长乘指令,指令将Rm和Rs中的值做有符号数相乘,结果的低32位保存到RsLo中,而高32位保存到RdHi中
      2、语法格式
        SMULL{<condition>}{S} <RdLo>,<RdHi>,<Rm>,<Rs>
      3、实例
        完成(R3,R2)=R7*R6  
        SMULL R2,R3,R7,R6

    六、SMLAL有符号长乘-累加操作指令
      1、作用
        SMLAL为64位有符号长乘法指令,指令将Rm和Rs中的值做有符号数相乘,64位乘积与RdHi,RdLo相加,结果的低32位保存到RsLo中,而高32位保存到RdHi中。
      2、语法指令
        SMLAL{<condition>}{S} <RdLo>,<RdHi>,<Rm>,<Rs>
      3、实例
        完成(R3,R2)=R7*R6+(R3,R2)
        SMLAL R2,R3,R7,R6

  • 相关阅读:
    JavaFx初探
    TraceView总结
    sprintf,你知道多少?
    C/C++:多个.cpp文件包括同一个.h头文件定义方法
    Android中Preference的使用以及监听事件分析
    Android系统默认Home应用程序(Launcher)的启动过程源码分析
    升级、备份红帽PaaS openshift 上的 wordpress
    几种开源分词工具的比較
    设计模式奠基石——UML关系转化为代码
    Windows 7系统安装MySQL5.5.21图解
  • 原文地址:https://www.cnblogs.com/zjzsky/p/3532818.html
Copyright © 2011-2022 走看看