作业-12.20【汇编实现判断循环两数相等,实现for循环1-100相加】

题目如图

 代码主体

.text
.globl _gcd
_gcd:

	mov r0, #9
	mov r1, #15
	
loop:
	cmp r0,r1
	beq stop
	subgt r0,r0,r1
	bgt loop
	sub r1,r1,r0
	b loop
	
stop:
	b stop


.end
	

 map.lds文件的修改


OUTPUT_FORMAT("elf32-littlearm", "elf32-littlearm", "elf32-littlearm")
/*OUTPUT_FORMAT("elf32-arm", "elf32-arm", "elf32-arm")*/
OUTPUT_ARCH(arm)
ENTRY(_gcd)
SECTIONS
{
	. = 0x00000000;
	. = ALIGN(4);
	.text      :
	{
		./Objects/gcd.o(.text)
		*(.text)
	}
	. = ALIGN(4);
    .rodata : 
	{ *(.rodata) }
    . = ALIGN(4);
    .data : 
	{ *(.data) }
    . = ALIGN(4);
	__bss_start = .; 
    .bss :
     { *(.bss) }
	__bss_end__ = .;
}

 效果

        第一轮

        第二轮

         第三轮(结束)

用汇编实现for循环实现1~100相加

代码

.text
.globl _start

_start:

	mov r0, #0
	mov r1, #1

loop:
	add r0,r0,r1
	add r1,r1,#1
	
	cmp r1,#101
	
	beq stop
	b loop


stop:
	b stop

.end

效果(最终结果为0x13BA即5050)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值