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

  • 相关阅读:
    剑指offer字符串列表
    剑指offer数组3
    剑指offer数组2
    剑指offer数组1
    剑指offer数组列表
    tensorflow+ssd_mobilenet实现目标检测的训练
    Win7+keras+tensorflow使用YOLO-v3训练自己的数据集
    Java是如何实现跨平台的
    Xshell 、PuTTY 复制文件到Linux
    Asp.Net Core2.0在linux下发布
  • 原文地址:https://www.cnblogs.com/zjzsky/p/3532818.html
Copyright © 2011-2022 走看看