你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

熟悉和习惯r2的基本使用

[复制链接]
gaosmile 发布时间:2020-12-5 23:20
首先你要有一个bin文件(bin文件的获取方法不在此展开介绍,今后有机会可以专门开一个贴聊一聊)。本次实验用到的bin文件  stm32_xwrtos.bin.zip (6 KB) 是用ST官方CMSIS和外设库编译的跑在stm32f103c8t6上的bin文件,比较具有代表性。
烧录文件下载:
工具准备:
安装开源跨平台逆向神器r2 https://github.com/radareorg/radare2 ,r2可运行在Windows、Linux、Mac等所有主流操作系统上(r2有多牛逼不在此展开介绍,今后有机会可以专门开一个贴聊一聊)。
' l+ |: q+ v+ K, T* k9 T$ l, ^+ T
: X6 N- Y3 A* C$ o实验步骤:
( V: F& Z6 \- L; f' Q' f1)输入r2 -a arm -b 16 -m 0x08000000 stm32_xwrtos.bin 进入r2的控制台后,输入e asm.cpu=cortex。这一步是告诉r2以0x08000000为基址加载stm32_xwrtos.bin文件,并设置指令集为cortex系列的thumb。
$ I  b, w* n5 I# f
微信图片_20201205231827.png
2)输入aaaa,运行自动化分析。
. _) K1 ~/ n- L
微信图片_20201205231831.png
3)输入pxw 268 @0x08000000 以小端四字节形式打印从0x08000000开始的268(268对应中断向量表大小)个字节,同时打开ST官方的启动文件startup_stm32f10x_md.s并找到.isr_vector段进行对照。0 e! a6 Y$ y- i
微信图片_20201205231834.png
4)接着上一步,输入fs notes,创建并切换到一个名为notes(可以是任意其他名字)的符号记事本;按照f flag=address的形式,对照.isr_vector段,向符号记事本中录入感兴趣的符号地址对应关系。注意如果address是函数地址则需要减1(因为thumb指令的要求,具体原因此处不展开);最后输入af @flag形式的命令强制进行函数分析。
微信图片_20201205231837.png
5) 输入pdf @Reset_Handler,对Reset_Handler函数进行反汇编
( g; [8 h# q0 P- J5 E" ]* c! Z3 r
微信图片_20201205231841.png
输入 VV 切换到流程图视图. U1 Q3 m+ \4 J& t' u. M% z1 k; ~
微信图片_20201205231843.png
通过阅读汇编代码,可以得到以下信息:
% T. O5 B8 u/ t: p7 Z$ h4 z( U1.  data段的地址区间为0x20000000-0x20000028 bss段的地址区间为0x20000028-0x2000043C
2.  Reset_Handler用0x08002cbc开始的0x28字节初始化data段,用0填充bss段
3. 调用fcn.08001cc8函数4. 调用fcn.08001734函数# e! v1 @8 n2 r& B( E$ ?0 n
" z( T3 F% i* {& P+ ~; J
6)输入pdf @fcn.08001cc8进行反汇编" l6 ^, R0 K6 u  s" j1 b) V
微信图片_20201205231846.png
发现对外设寄存器地址0x40021000的引用$ V. I7 F/ k2 M& v" Y
微信图片_20201205231849.png
通过查询数据手册,可判断fcn.08001cc8函数应为系统初始化化函数SystemInit(),它初始化了时钟8 Y0 X4 n" t0 J

1 L3 P" O0 M6 E6 I' b$ J7)根据经验判断fcn.0800173函数即为main函数
本篇作为系列第一篇文章,主要作用是带大家熟悉和习惯r2的基本使用,以及对逆向有个感性认识。下一篇计划在逆向的基础上介绍stm32上的栈溢出漏洞的挖掘与利用。

* q' m7 h* q! {$ E6 d6 r+ P
收藏 1 评论0 发布时间:2020-12-5 23:20

举报

0个回答
关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版