havenow 发表于 2021-3-18 22:28

如何动态调试来学习ARM汇编 3 CPSR寄存器

本帖最后由 havenow 于 2021-3-18 22:33 编辑

当前程序状态寄存器cpsr寄存器显示出CPSR寄存器的当前值,在他的下面一行,你可以看到标志位 thumb, fast, interrupt, overflow, carry, zero, 以及 negative。这些标志位显示了CPSR寄存器中的某些特定的位,根据CPSR的值,当某个位被激活时,对应的字体会变成粗体。其中,N,Z,C和V标志位分别和x86寄存器的SF,ZF,CF和OF标志位表示的含义一一对应。这些标志位用来在汇编级别条件执行指令和循环指令中支配他们执行。





标记 含义
N(Negative) 指令执行结果为负时置1
Z(Zero) 指令执行结果为0时置1
C(Carry) 加法有进位则置1否则置0,减法有借位则置0否则置1
V(overflow) 指令执行结果超出32位补码存储范围时置1
E(Endian-bit) 置0时使用小端序,置1时使用大端序
T(Thumb-bit) 置1时使用Thumb模式,置0时使用ARM模式
M(Mode-bit) 共5位表示处理器运行模式
J(Jazelle) 对于有的处理器,置位表示允许以硬件执行java字节码

看看下面的代码
      .text
      .globl      main
main:
      mov r1, #1
      mov r2, #2
      cmp r1, r2
      cmp r2, r1
      cmp r2, r2
      bx lr

假设我们用cmp指令来比较1和2,结果将为负,Negative标志位被置1。因为cmp指令执行一次隐式的减法操作,1-2=-1。


如果我们比较2和1(和刚才相反),减法操作不借位,Carry标志位被置1。


如果我们比较两个相同的数,比如2和2,那么2-2=0,在Carry标志位置1的同时,Zero标志位也被置1。

      

sjzdevin 发表于 2021-3-18 23:00

努力追随到最后

SD1 发表于 2021-3-18 23:21

学习了+1

masongxin9 发表于 2021-3-18 23:51

很复杂,不过很流畅

xiaojiakeji 发表于 2021-3-19 00:05

太高大上了,,可以分享视频嘛

fazeroquan 发表于 2021-3-19 10:16

滴滴滴,学习加油!

goda 发表于 2021-3-19 14:40

ok,明白

酱鸭腿 发表于 2021-3-21 19:11

原来是这个样子滴,学习了。
页: [1]
查看完整版本: 如何动态调试来学习ARM汇编 3 CPSR寄存器