乘法指令之:MUL乘法指令
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.1MUL乘法指令1.指令编码格式MUL(Multiply)32位乘法指令将Rm和Rs中的值相乘,结果的最低32位保存到Rd中。
指令的编码格式如图7.2所示。
图7.2MUL指令的编码格式
您可能也感兴趣:
为您推荐
去年社保“成绩单”亮眼 社保基金监管再戴“紧箍咒”
“冰雪保险”讨论度升温 购买此类产品时需看清投保须知
我国重疾险发展迎来较大挑战,多因素致销售增长遇瓶颈
排行
最近更新
- 乘法指令之:MUL乘法指令
- 强电和弱电的区别- -电压高低??No
- 思鸿网校:初级会计考试多选题答题技巧!
- 思鸿网校初级会计备考,总是状态不好怎么办?
- 2022上海国际制冷设备及冷链物流展览会|制冷冰箱空调展览会
- 思鸿网校2022年初级会计单、多选每日一练
- 思鸿网校中级会计职称考试,每日一练坚持打卡!
- 新学期伊始,重庆海联职业技术学院的同学们状态很在线
- 中信证券:进入3月货币宽松窗口期仍未结束 后续降准依然有较...
- 联合国际:下调力高集团国际长期发行人评级至“B”,评级列入...
- 成都玖锦:电子测量仪器国内市场近400亿 国产高端仪器的机遇...
- 深圳高质量推进高新区建设 “创新”集群、创新要素充分涌现
- 【积加ERP亮点100】运营日志:快速沉淀运营经验,高效打造爆款套路
- 聚力公益,为爱科普,德琪医药助力“国际骨髓瘤关爱月” 系...
- BitBank数字资产钱包获得千万美金投资
- 年轻人成为线上黄金消费主力
- 特色水果走红的启示(新知)
- 食品提价引发“蝴蝶效应” 节后终端消费趋平淡
- 推进废旧家电绿色回收要多算“大账”
- 欧洲多国和俄罗斯互相“禁飞” 报复性举措给航空业带来灾难...
- 人身险产品为何需要“负面清单”
- 银城拟1.65亿美元2022年到期美元票据提出交换要约 新票据年...
- 序贯免疫是“混打”吗?哪些人符合条件?一图读懂
- 京城佳业预计自全球发售实际调回所得款项2.73亿港元
- 促进工业经济平稳增长政策如何精准发力?专家解读
- 深圳推出多项政策支持贸易型总部企业发展 建设全球重要的商...
- 深圳高新区“长出”海量科技企业 强势推动新兴产业集群发展
- 我国网民规模达10.32亿 有影响力的工业互联网平台超150个
- 我国投资者数量不断增长 证券行业开立A股资金账户数达2.98亿个
- 加入生命体征监测的智慧病房2.0已来!桂花网蓝牙物联网奏功!