之前看到过一个延时函数段:
delay:
ldr r2, =7000000
ldr r3, =0x0
delay_loop:
sub r2, r2, #1 //r2=r2-1
cmp r2, r3 //cmp会影响z标志位,如果r2=r3,则Z=1;下一句中eq就会成立
bne delay_loop //
mov pc, lr //函数返回 延时函数
现在我们来分析一下这个函数的各个指令。
1、cmp比较指令
假设现在AX寄存器中的数是0004H,BX寄存器中的数是0007H。
执行的指令是:CMP AX, BX
执行这条指令时,先做用AX中的数减去BX中的数的减法运算。各标志位将会被分别设置成以下值:
CF:是否有进位或者借位
ZF:0标志位,就是结果是否为0
OF:溢出标志位,是否计算机结果溢出了
SF:符号位,0为正,1为负
2、bne指令
bne: 标志寄存器中Z标志位不等于零时, 跳转到BNE后标签处
beq: 标志寄存器中Z标志位等于零时, 跳转到BEQ后标签处
上面函数中,比较了r2和r3,它们相减,如果结果为0,那么Z标志位置位,就不跳转了,否则就会跳转,形成循环
3、sub r2,r2,#1
把r2里的数减1,然后放回r2里面。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。