如果碰到智能设备的程序,我们应该怎样动态逆向分析呢?
一、环境准备
首先,需要搭建嵌入式开发环境。并不一定需要硬件平台,可以使用ubuntu进行模拟。在unbuntu主机上安装一个arm操作系统。系统采用nfs方式挂载文件系统。
安装qemu-system-arm
apt-get install qemu-system-arm
假设手头上已有基于arm的linux内核、设备、根文件系统,则运行qemu-system-arm启动。引导命令类似于:
qemu-system-arm -M vexpress-a9 -m 128M -dtb vexpress-v2p-ca9.dtb
-kernel zImage -append "root=/dev/mmcblk0 rw" -sd a9rootfs
上述启动命令面向于vexpress-a9目标板,需要逆向的是a9rootfs
启动后会出现如下的界面
data:image/s3,"s3://crabby-images/3dbc4/3dbc48f5cce428ae061e3c6889ecb3db3a34459a" alt=""
用Explore2fs提取文件系统中的文件,找出需要分析的ELF文件,并从文件系统中提取出来。
为了调试程序,需要安装qemu-user。
apt install qemu-user
二、远程调试
qemu的远程调试比较简单,采用-g参数绑定本地端口即可。假设此时我们需要分析的程序为./sh,则在ubuntu中运行下述命令
qemu-arm -g 12345 ./sh
在IDA中,选择Remote GDB debugger来attach
data:image/s3,"s3://crabby-images/0a3fb/0a3fb11d45265b3019ef44e10f9a25141905790b" alt=""
填写远程主机IP和端口。本示例中填写12345端口。
data:image/s3,"s3://crabby-images/1de9a/1de9af58e3864bc895c9f038db030abf38d3ad7e" alt=""
同时,点击“Debug options”按钮,配置调试选项。勾选Suspend on debugging start, Suspend on process entry point。
data:image/s3,"s3://crabby-images/21dc6/21dc608b14e26fedc451bbb909df25fd0537943c" alt=""
点击“Set specific options”,执行目标进程的架构,本示例中选择ARM Little-endian。
data:image/s3,"s3://crabby-images/fd902/fd9020fa342ea82cfe66dad8ae0271b518b58522" alt=""
如何选择架构呢?这些信息使用readelf –h file就能查看到。
data:image/s3,"s3://crabby-images/6d64d/6d64d18206a78a879ae796c893928a505f4ccdf3" alt=""
设置完毕后,如果前面的配置都正确则会弹出如下对话框。
data:image/s3,"s3://crabby-images/1a86c/1a86c1fec6a5763788b2879ed895171a97b32adb" alt=""
之后就出现熟悉的IDA调试界面,可以设置断点,浏览和调试该可执行程序的运行过程以及内存情况。
data:image/s3,"s3://crabby-images/7ef8e/7ef8ec7a3878de522a4a6ec0dc2b7eebd4179a22" alt=""
网友评论