Android ARM逆向

ARM 汇编的一些知识

寄存器数量
不同模式下访问的寄存器
寄存器用途
条件执行后缀
ARM 的指令流水线
IDA 中的一些设置
so 文件加载断点
android studio 只生成 ARM 的 so 文件
IDA 中添加自动注释
Dump 内存
使用 IDA 分析 so 文件-导入 Jni.h 识别类型

ARM 汇编的一些知识
寄存器数量
ARM 处理器一共有 37 个 32 位寄存器。
30 个为“通用“寄存器: r0-r14
未分组:r0-r7,即只有一个寄存器
分 组:r8-r14,即有多个同名寄存器
r8-r12 :两个
r13-r14:6 个 r13(sp),R14(lr)
1 个固定的程序计数器 : pc (又称 r15)
6 个为状态寄存器。 : cpsr spsr
不能被同时访问,一种模式下最多同时访问 18 个寄存器

不同模式下访问的寄存器


image.png

寄存器用途
sp(r13) - 堆栈指针
lr(r14) - 连接寄存器
调用子程序时存放调用地址,存放返回地址
pc(r15) - 程序计数器,相当于 windows 的 EIP
(1)跳转到指定地址
mov pc,lr // 直接修改 pc ,完成跳转
bx lr // 跳转到 lr 保存的地址
(2)在函数入口保存寄存器信息
stmfd sp!, {r11,lr} // 保存大括号中的寄存器到栈中,从右往左

(3)使用 ldm 指令修改 pc,完成函数返回
ldmfd sp!, {r11,pc} // 将栈中数据依次加载到寄存器中,从左往右
cpsr – 当前程序状态寄存器
spsr–备份的程序状态寄存器

条件执行后缀


image.png

无条件跳转指令: B
带条件跳转指令:BXX,BNE, BEQ

ARM 的指令流水线

image.png

ARM 指令 当前执行的 PC 和与看到的 PC 相差 8
即 看汇编时,需要 pc+8 才是真正的 pc
Thumb 指令 当前执行的 PC 和与看到的 PC 相差 4
即 看汇编时,需要 pc+4 才是真正的 pc
0001000 mov r0, #8 ; r0 = 8
0001004 add r0,pc,r0 r0 =pc+r0 = r0 + 当前指令+8+r0

IDA 中的一些设置
在打开的 IDA 数据库文件中,直接附加调试 so 文件时会有警告提示

image.png
image.png

选择指令地址,快捷键 Alt+G,可以切换指令集


image.png

在 IDA 动态调试时,使用插件 KeyPatch 可以汇编 ARM 指令或者 thumb 指令
Keypatch 是一个 python 插件,其要求是 python2.7 ,依赖一个库 keystone

image.png

so 文件加载断点
① Init 段的 init_proc 函数(linker, so 文件加载的解释器模块)
② Init_array 段的构造数组函数(linker)
③ Jni_Onload(libdvm.so)
第一步:分析 android 源码,找到调用的代码

image.png
image.png

第二步:根据代码,定位到模块
可以看到源码是 linker.cpp, 模块就是在 linker 模块
第三步:根据源码特征,在模块中定位到反汇编代码
从 android 设备中下载 linker 模块,模块是/system/bin 目录下

image.png

根据字符串定位: Calling %s @ %p for '%s'

image.png

查找数据引用的代码,找到调用代码

image.png

274C
第四步:下断点


image.png

② 找 Jni_Onload 函数


image.png
image.png

函数指针调用,说明也是寄存器调用
("[Calling JNI_OnLoad for "%s"]"
Jni_Onload 调用的模块是在 system/lib/libdvm.so

image.png

503cc

image.png

41464000+503cc=414B43CC
系统:android 4.4.4_r1
linker: 274C 调用 init 段以及 init_array 段的函数的偏移
libdvm.so: 503cc, 调用 JNI_Onload 的偏移
android studio 只生成 ARM 的 so 文件

image.png

IDA 中添加自动注释


image.png

效果如下:


image.png

Dump 内存
输入脚本命令的窗口

image.png

使用 Ctrl+S,查看模块内存,找到需要 dump 的模块,找到首地址和结束地址
static main(void)
{
auto fp, begin, end, dexbyte;
fp = fopen("F:\dump.so", "wb");
begin = 0x75394000;
end = 0x7539a000;
for ( dexbyte = begin; dexbyte < end; dexbyte ++ )
fputc(Byte(dexbyte), fp);
}

使用 IDA 分析 so 文件-导入 Jni.h 识别类型


image.png

导入 jni.h 之后,可以修改参数类型


image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,743评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,296评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,285评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,485评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,581评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,821评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,960评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,719评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,186评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,516评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,650评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,329评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,936评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,757评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,991评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,370评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,527评论 2 349

推荐阅读更多精彩内容