之前看到过一个延时函数段:


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里面。