吾爱破解 - LCG - LSG |安卓破解|病毒分析|www.52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2213|回复: 7
收起左侧

[Android 原创] 如何动态调试来学习ARM汇编 3 CPSR寄存器

[复制链接]
havenow 发表于 2021-3-18 22:28
本帖最后由 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标志位表示的含义一一对应。这些标志位用来在汇编级别条件执行指令和循环指令中支配他们执行

cpsr

cpsr




标记 含义
NNegative 指令执行结果为负时置1
ZZero 指令执行结果为0时置1
CCarry 加法有进位则置1否则置0,减法有借位则置0否则置1
Voverflow 指令执行结果超出32位补码存储范围时置1
EEndian-bit 0时使用小端序,置1时使用大端序
TThumb-bit 1时使用Thumb模式,置0时使用ARM模式
MMode-bit 5位表示处理器运行模式
JJazelle 对于有的处理器,置位表示允许以硬件执行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。

cmp1

cmp1


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

cmp2

cmp2


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

cmp3

cmp3

        

免费评分

参与人数 5吾爱币 +8 热心值 +5 收起 理由
qtfreet00 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
Tony2009 + 1 我很赞同!
mayl8822 + 1 + 1 谢谢@Thanks!
gzshlp + 1 我很赞同!
Lsf286445997 + 1 鼓励转贴优秀软件安全工具和文档!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

sjzdevin 发表于 2021-3-18 23:00
努力追随到最后
SD1 发表于 2021-3-18 23:21
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
原来是这个样子滴,学习了。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则 警告:本版块禁止灌水或回复与主题无关内容,违者重罚!

快速回复 收藏帖子 返回列表 搜索

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-5-4 06:05

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表