之前看到过一个延时函数段:
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里面。