用ARM汇编实现64位数据的运算

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】


来自:http://blog.sina.com.cn/s/blog_6238e8790100nx7h.html

你可能感兴趣的:(用ARM汇编实现64位数据的运算)