【android 逆向】arm if
#include <stdio.h>
void if1(int n){ //if else语句
if(n < 10){
printf("the number less than 10\n");
} else {
printf("the number greater than or equal to 10\n");
}
}
void if2(int n){ //多重if else语句
if(n < 16){
printf("he is a boy\n");
} else if(n < 30){
printf("he is a young man\n");
} else if(n < 45){
printf("he is a strong man\n");
} else{
printf("he is an old man\n");
}
}
int main(int argc, char* argv[]){
if1(5);
if2(35);
return 0;
}
.text:00008570
.text:00008570
.text:00008570
.text:00008570 if2 ; CODE XREF: main+10↓p
.text:00008570 ; __unwind {
.text:00008570 CMP R0, #0xF
.text:00008574 BLE loc_85A0 ; if arg0 <= 15 跳转
.text:00008578 CMP R0, #0x1D
.text:0000857C BLE loc_85AC ; if arg0 <= 16+13 =29
.text:00008580 CMP R0, #0x2C ; ','
.text:00008584 BLE loc_8594 ; if arg0 <= 44
.text:00008588 LDR R0, =(aHeIsAnOldMan - 0x8594) ; "he is an old man"
.text:0000858C ADD R0, PC, R0 ; "he is an old man"
.text:00008590 B puts
.text:00008594 ; ---------------------------------------------------------------------------
.text:00008594
.text:00008594 loc_8594 ; CODE XREF: if2+14↑j
.text:00008594 LDR R0, =(aHeIsAStrongMan - 0x85A0) ; "he is a strong man"
.text:00008598 ADD R0, PC, R0 ; "he is a strong man"
.text:0000859C B puts
.text:000085A0 ; ---------------------------------------------------------------------------
.text:000085A0
.text:000085A0 loc_85A0 ; CODE XREF: if2+4↑j
.text:000085A0 LDR R0, =(aHeIsABoy - 0x85AC) ; "he is a boy"
.text:000085A4 ADD R0, PC, R0 ; "he is a boy"
.text:000085A8 B puts
.text:000085AC ; ---------------------------------------------------------------------------
.text:000085AC
.text:000085AC loc_85AC ; CODE XREF: if2+C↑j
.text:000085AC LDR R0, =(aHeIsAYoungMan - 0x85B8) ; "he is a young man"
.text:000085B0 ADD R0, PC, R0 ; "he is a young man"
.text:000085B4 B puts
.text:000085B4 ; End of function if2
.text:000085B4
.text:000085B4 ; ---------------------------------------------------------------------------
.text:000085B8 off_85B8 DCD aHeIsAnOldMan - 0x8594
.text:000085B8 ; DATA XREF: if2+18↑r
.text:000085B8 ; "he is an old man"
.text:000085BC off_85BC DCD aHeIsAStrongMan - 0x85A0
.text:000085BC ; DATA XREF: if2:loc_8594↑r
.text:000085BC ; "he is a strong man"
.text:000085C0 off_85C0 DCD aHeIsABoy - 0x85AC ; DATA XREF: if2:loc_85A0↑r
.text:000085C0 ; "he is a boy"
.text:000085C4 off_85C4 DCD aHeIsAYoungMan - 0x85B8
.text:000085C4 ; DATA XREF: if2:loc_85AC↑r
.text:000085C4 ; } // starts at 8570 ; "he is a young man"
.text:000085C8
.text:000085C8 ; =============== S U B R O U T I N E =======================================
.text:000085C8
.text:000085C8
.text:000085C8 if1 ; CODE XREF: main+8↓p
.text:000085C8 ; __unwind {
.text:000085C8 CMP R0, #9
.text:000085CC BLE loc_85DC ; if arg0 <= 9 跳转
.text:000085D0 LDR R0, =(aTheNumberGreat - 0x85DC) ; "the number greater than or equal to 10"
.text:000085D4 ADD R0, PC, R0 ; "the number greater than or equal to 10"
.text:000085D8 B puts
.text:000085DC ; ---------------------------------------------------------------------------
.text:000085DC
.text:000085DC loc_85DC ; CODE XREF: if1+4↑j
.text:000085DC LDR R0, =(aTheNumberLessT - 0x85E8) ; "the number less than 10"
.text:000085E0 ADD R0, PC, R0 ; "the number less than 10"
.text:000085E4 B puts
.text:000085E4 ; End of function if1
.text:000085E4
.text:000085E4 ; ---------------------------------------------------------------------------
.text:000085E8 off_85E8 DCD aTheNumberGreat - 0x85DC
.text:000085E8 ; DATA XREF: if1+8↑r
.text:000085E8 ; "the number greater than or equal to 10"
.text:000085EC off_85EC DCD aTheNumberLessT - 0x85E8
.text:000085EC ; DATA XREF: if1:loc_85DC↑r
.text:000085EC ; } // starts at 85C8 ; "the number less than 10"
.text:000085F0
.text:000085F0 ; =============== S U B R O U T I N E =======================================
.text:000085F0
.text:000085F0
.text:000085F0 ; int __cdecl main(int argc, const char **argv, const char **envp)
.text:000085F0 main ; CODE XREF: j_main↑j
.text:000085F0 ; __unwind {
.text:000085F0 PUSH {R4,LR}
.text:000085F4 MOV R0, #5
.text:000085F8 BL if1 ; if1
.text:000085FC MOV R0, #0x23 ; '#' ; 35
.text:00008600 BL if2 ; if2
.text:00008604 MOV R0, #0
.text:00008608 POP {R4,PC}
.text:00008608 ; } // starts at 85F0
.text:00008608 ; End of function main
【android 逆向】arm if的更多相关文章
- android逆向学习小结--CrackMe_1
断断续续的总算的把android开发和逆向的这两本书看完了,虽然没有java,和android开发的基础,但总体感觉起来还是比较能接收的,毕竟都是触类旁通的.当然要深入的话还需要对这门语言的细节特性和 ...
- Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码)
Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码) 来源 https://blog.csdn.net/jiangwei0910410003/article/details/51 ...
- 【基于Android的ARM汇编语言系列】之五:ARM指令集与Thumb指令集
作者:郭嘉 邮箱:allenwells@163.com 博客:http://blog.csdn.net/allenwells github:https://github.com/AllenWell [ ...
- 2021年正确的Android逆向开发学习之路
2021年正确的Android逆向开发学习之路 说明 文章首发于HURUWO的博客小站,本平台做同步备份发布.如有浏览或访问异常或者相关疑问可前往原博客下评论浏览. 原文链接 2021年正确的Andr ...
- [转]Android逆向之动态调试总结
一.在SO中关键函数上下断点 刚学逆向调试时.大多都满足于在SO中某关键函数上下断点.然后通过操作应用程序,去触发这个断点,然后进行调试 详细的步骤可以参见非虫大大的<Android软件安全与逆 ...
- Android逆向之so的半自动化逆向
因为工作需要,转型干android逆向,有几个月了.不过对于so的逆向,任然停留在,难难难的阶段,虽然上次自己还是逆向了一个15k左右的小so文件,但是,那个基本是靠,一步一步跟代码,查看堆栈信息来自 ...
- Android逆向破解表单注册程序
Android逆向破解表单注册程序 Android开发 ADT: android studio(as) 程序界面如下,注册码为6位随机数字,注册成功时弹出通知注册成功,注册失败时弹出通知注册失败. 布 ...
- Android逆向破解表单登录程序
Android逆向破解表单登录程序 Android开发 ADT: android studio(as) 程序界面如下,登录成功时弹出通知登录成功,登录失败时弹出通知登录失败. 布局代码 <?xm ...
- Android逆向之静态分析
想必打过CTF的小伙伴多多少少都触过Android逆向,所以斗哥将给大家整一期关于Android逆向的静态分析与动态分析.本期先带来Android逆向的静态分析,包括逆向工具使用.文件说明.例题解析等 ...
- Android 逆向实战篇(加密数据包破解)
1. 实战背景由于工作需要,要爬取某款App的数据,App的具体名称此处不便透露,避免他们发现并修改加密逻辑我就得重新破解了. 爬取这款App时发现,抓包抓到的数据是加密过的,如图1所示(原数据较长, ...
随机推荐
- SAP APO-PP / DS
在SAP APO中,使用生产计划/详细计划(Production Planning/Detailed Scheduling)生成满足生产要求的采购建议. 此组件还用于定义资源计划和订单明细. 您还可以 ...
- SAP 实例 6 HTML input
REPORT demo_html_input. CLASS demo DEFINITION. PUBLIC SECTION. CLASS-METHODS main. PRIVATE SECTION. ...
- sql-DQL-单表查询
单表查询 select [distint]* 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限定 ...
- NC20241 [SCOI2005]扫雷MINE
NC20241 [SCOI2005]扫雷MINE 题目 题目描述 相信大家都玩过扫雷的游戏.那是在一个 \(n \times m\) 的矩阵里面有一些雷,要你根据一些信息找出雷来. 万圣节到了 ,&q ...
- vmstate 命令详解2022
vmstat 是一个查看虚拟内存(Virtual Memory)使用状况的工具,但是怎样通过 vmstat 来发现系统中的瓶颈呢? 1. 使用vmstat 使用前我们先看下命令介绍及参数定义 Usag ...
- 6 分钟看完 BGP 协议。
上一篇文章见 万字长文爆肝路由协议! 上面我们聊 RIP .OSPF 协议都是基于 AS 即自治系统内的协议,可以把它们认为是域内路由协议:而下面我们要聊的就是 AS 之间的协议了,这也叫做域间路由协 ...
- 如何准备论文线上Presentation视频录制教程(Summary of Video Recording)
0:前言 由于国外的疫情严重,目前大多数学术会议都是线上举办,因此往往需要制作presentation的视频录制.由于各种软件横飞,有的需要会员并且不熟悉操作,特别浪费时间.因此,我将这次的操作和遇到 ...
- Overfitting & Train Set & Test Set
假设数据集是独立同分布的,可以将数据集划分为不同的比例:Train Set and Test Set. 同时在Train Set and Test Set上做精度测试,或者隔一段时间在Test Set ...
- 最强人工智能 OpenAI 极简教程
大家好哇,新同学都叫我张北海,老同学都叫我老胡,其实是一个人,只是我特别喜欢章北海这个<三体>中的人物,张是错别字. 上个月安利了一波:机器学习自动补全代(hán)码(shù)神器,然后就 ...
- 渗透测试(PenTest)基础指南
什么是渗透测试? 渗透测试(Penetration Test,简称为 PenTest),是指通过尝试利用漏洞攻击来评估IT基础设施的安全性.这些漏洞可能存在于操作系统.服务和应用程序的缺陷.不当配置或 ...