ARM条件码与CPSR标志位的关系——cmp MOVLS与MOVHI 指令
2012-08-31 16:13
246 查看
今天看到CMP,代码如下
MOV R0, #5
MOV R1, #6
CMP R0, R1
MOVLS R2, R0 ; if R0 < R1 则 将小值存入R2中
有个MOVLS与MOVHI 很是不解,经过查资料,原来是ARM条件码与CPSR标志位的关系。
CPSR中的Z, C, N, V标志位:
[align=left]l 0000 = EQ - Z set (equal)[/align]
[align=left]l 0001 = NE - Z clear (not equal)[/align]
[align=left]l 0010 = CS - C set (unsigned higher or same)[/align]
[align=left]l 0011 = CC - C clear (unsigned lower)[/align]
[align=left]l 0100 = MI - N set (negative)[/align]
[align=left]l 0101 = PL - N clear (positive or zero)[/align]
[align=left]l 0110 = VS - V set (overflow)[/align]
[align=left]l 0111 = VC - V clear (no overflow)[/align]
[align=left]l 1000 = HI - C set and Z clear (unsigned higher)[/align]
[align=left]l 1001 = LS - C clear or Z set (unsigned lower or same)[/align]
[align=left]l 1010 = GE - N set and V set, or N clear and V clear (greater or equal)[/align]
[align=left]l 1011 = LT - N set and V clear, or N clear and V set (less than)[/align]
l 1100 = GT - Z clear, and either N set and V set, or N clear and V clear (greater
than)
[align=left]l 1101 = LE - Z set, or N set and V clear, or N clear and V set (less than or equal)[/align]
[align=left]l 1110 = AL - always[/align]
[align=left]l 1111 = NV - never[/align]
[align=left] [/align]
MOVLS R2, R0 ; if R0 < R1 则 将小值存入R2中
在这个例子中,MOVLS 能够正确执行的条件C=0 and z=1 成立,是通过CMP设置了。
若执行指令后
ZF=1 这个简单,则说明两个数相等,因为zero为1说明结果为0
当无符号时:
若
CF=1 则说明了有进位或借位,cmp是进行的减操作,故可以看出为借位,所以,此时oprd1<oprd2
CF=0 则说明了无借位,但此时要注意ZF是否为0,若为0,则说明结果不为0,故此时oprd1>oprd2
当有符号时:
若SF=0,OF=0 则说明了此时的值为正数,没有溢出,可以直观的看出,oprd1>oprd2
若SF=1,OF=0 则说明了此时的值为负数,没有溢出,则为oprd1<oprd2
若SF=0,OF=1 则说明了此时的值为正数,有溢出,可以看出oprd1<oprd2
若SF=1,OF=1则说明了此时的值为负数,有溢出,可以看出oprd1>oprd2
最后两个可以作出这种判断的原因是,溢出的本质问题:
两数同为正,相加,值为负,则说明溢出
两数同为负,相加,值为正,则说明溢出
故有,正正得负则溢出,负负得正则溢出
[align=left] [/align]
MOV R0, #5
MOV R1, #6
CMP R0, R1
MOVLS R2, R0 ; if R0 < R1 则 将小值存入R2中
有个MOVLS与MOVHI 很是不解,经过查资料,原来是ARM条件码与CPSR标志位的关系。
CPSR中的Z, C, N, V标志位:
[align=left]l 0000 = EQ - Z set (equal)[/align]
[align=left]l 0001 = NE - Z clear (not equal)[/align]
[align=left]l 0010 = CS - C set (unsigned higher or same)[/align]
[align=left]l 0011 = CC - C clear (unsigned lower)[/align]
[align=left]l 0100 = MI - N set (negative)[/align]
[align=left]l 0101 = PL - N clear (positive or zero)[/align]
[align=left]l 0110 = VS - V set (overflow)[/align]
[align=left]l 0111 = VC - V clear (no overflow)[/align]
[align=left]l 1000 = HI - C set and Z clear (unsigned higher)[/align]
[align=left]l 1001 = LS - C clear or Z set (unsigned lower or same)[/align]
[align=left]l 1010 = GE - N set and V set, or N clear and V clear (greater or equal)[/align]
[align=left]l 1011 = LT - N set and V clear, or N clear and V set (less than)[/align]
l 1100 = GT - Z clear, and either N set and V set, or N clear and V clear (greater
than)
[align=left]l 1101 = LE - Z set, or N set and V clear, or N clear and V set (less than or equal)[/align]
[align=left]l 1110 = AL - always[/align]
[align=left]l 1111 = NV - never[/align]
[align=left] [/align]
MOVLS R2, R0 ; if R0 < R1 则 将小值存入R2中
在这个例子中,MOVLS 能够正确执行的条件C=0 and z=1 成立,是通过CMP设置了。
若执行指令后
ZF=1 这个简单,则说明两个数相等,因为zero为1说明结果为0
当无符号时:
若
CF=1 则说明了有进位或借位,cmp是进行的减操作,故可以看出为借位,所以,此时oprd1<oprd2
CF=0 则说明了无借位,但此时要注意ZF是否为0,若为0,则说明结果不为0,故此时oprd1>oprd2
当有符号时:
若SF=0,OF=0 则说明了此时的值为正数,没有溢出,可以直观的看出,oprd1>oprd2
若SF=1,OF=0 则说明了此时的值为负数,没有溢出,则为oprd1<oprd2
若SF=0,OF=1 则说明了此时的值为正数,有溢出,可以看出oprd1<oprd2
若SF=1,OF=1则说明了此时的值为负数,有溢出,可以看出oprd1>oprd2
最后两个可以作出这种判断的原因是,溢出的本质问题:
两数同为正,相加,值为负,则说明溢出
两数同为负,相加,值为正,则说明溢出
故有,正正得负则溢出,负负得正则溢出
[align=left] [/align]
相关文章推荐
- ARM条件码与CPSR标志位的关系
- ARM条件码与CPSR标志位的关系
- ARM条件码与CPSR标志位的关系
- ARM条件码与CPSR标志位的关系
- 操作影响cpsr的条件码的指令(teq等),与影响关系
- ARM MOV和 LDR指令关系
- ARM MOV和 LDR指令关系
- 通过cmp 指令执行后,相关标志位的值就可以看出比较的结果
- 通过cmp 指令执行后,相关标志位的值就可以看出比较的结果
- cmp(compare)指令
- MOV指令
- cpu指令和应用程序间关系
- mov eax,dword ptr fs:[0] 指令
- 时钟周期、机器周期、指令周期的概念及三者之间的关系
- movsb movsw movsd 指令详解
- Linux文本比较指令(diff,cmp)详解
- 汇编常用指令对标志位的影响(转)
- 蓝牙协议指令和字节数组的关系
- 8086 MOV 指令的注意事项
- LDR伪指令和LDR指令及MOV指令的区别