您的位置 首页 应用

用ARM汇编完成64位数据的运算

R0和R1分别存放一个64位操作数的低32位和高32位,R2和R3分别存放另一个64位操作数的低32位和高32位。一、64位操作数的加法运算ADDSR4,R0,

R0和R1别离寄存一个64位操作数的低32位和高32位,

R2和R3别离寄存另一个64位操作数的低32位和高32位。

一、64位操作数的加法运算

ADDS R4,R0,R2

ADC R5,R1,R3

ADDS指令中,R4=R0+R2,且是否有进位会影响到CPSR寄存器中的C标志位;

ADC指令R5=R1+R3+C,这样,R4和R5就寄存了64位和值的低32位和高32位。

二、64位操作数的减法运算

SUBS R4,R0,R2

SBC R5,R1,R3

SUBS指令中,R4=R0-R2,假如产生借位,则C=0【这和ADDS指令相反】;

SBC指令R5=R1-R3-C标志位的反码。

三、求64位操作数的负数

RSBS R2,R0,#0;R2=-R0,且产生了借位,则C标志位为0.

RSC R3,R1,#0 ;R3=-R1-C的反码【此处为1】

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/262981.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部