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


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