作业1 ------->实现两个64位数相减
.text
.global _start
_start:
@实现两个64位数相减
@第一个64位数:高32位用r0=0x6表示,低32位用r1 = 0x4表示
@第二个64位数:高32位用r2=0x2表示,低32位用r3 = 0x5表示
@实现两个64位数相减:高32位用r5表示,低32位相减r4表示
@ r4 = r1 - r3 = 0x4 - 0x5 = 0xffffffff
@ r5 = r0 - r2 = 0x6 - 0x2 - 1 = 0x3
mov r0,#0x6
mov r1,#0x4
mov r2,#0x2
mov r3,#0x5
subs r4,r1,r3
sbc r5,r0,r2
stop:
b stop
.end
执行结果
作业2———— 求两个数最大公约数
.text
.global _start
_start:
mov r0,#0x9
mov r1,#0x15
start:
cmp r0,r1
beq stop @如果 r0 = r1 停止
bl cmp_func
b start
cmp_func:
subhi r0,r0,r1 @如果 r0 > r1,r0 = r0 -r1
subcc r1,r1,r0 @如果 r0 < r1,r1 = r1 -r0
mov pc,lr
stop:
b stop
.end
执行结果
作业3—— 用for循环实现1~100之间的和
.text
.global _start
_start:
mov r0,#0x1 @相当于int i = 1
mov r1,#0x1 @ 定义一个1
mov r2,#0x65 @ 定义一个101,为100时要进入函数
mov r3,#0x0 @相当于int sum = 0,如果结果为13BA即正确
start:
cmp r0,r2
beq stop @如果 r0 = r2 停止
bl cmp_func
b start
cmp_func:
add r3,r3,r0
add r0,r0,r1
mov pc,lr
stop:
b stop
.end
执行结果