arm作业——2.15

作业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

执行结果

arm作业——2.15_第1张图片

作业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

执行结果

arm作业——2.15_第2张图片

作业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
	

执行结果

arm作业——2.15_第3张图片

 

你可能感兴趣的:(arm)