IDA内存断点的设置

前言

在IDA中单步,找到一段数据后,想看看数据是如何被使用的。
这时,如果再单步去跟cm流程,查看数据是如何被使用的,有点纠结。
随着作者思路的不同,使用数据的反汇编代码可能不在找到数据的反汇编代码附近。
这时,很容易将数据和程序流程跟丢了。
如何在找到数据后,对数据下内存访问断点。然后F9让cm跑起来,当内存访问断点命中后,停下来单步数据处理的逻辑,这样操作性强。

在网上找到的资料,如何在IDA中下内存访问断点,只是支言片语,可能回答者觉得这太基础了吧?

实验

实验环境

IDA7.0 + win10x64

*在代码区,g到找到的数据块地址。
*在数据块首地址按下F2,设置断点。
IDA内存断点的设置
*因为这个断点所在位置不是代码块,IDA会弹出设置对话框。可以在里面填数据块长度。
IDA内存断点的设置
*非必须,去看看断点列表,看看内存断点和执行断电的区别。
IDA内存断点的设置

*内存访问断点和执行断点的区别
IDA内存断点的设置
可以看到:
* 执行断点是软件断点。
* 内存访问断点是硬件断点。

*断点的命中
确定找到需要的数据块后,下好内存访问断点,F9跑起。
等命中时,就可以静静的分析数据是如何被使用的。
IDA内存断点的设置
e.g. 上图中,内存访问断点命中后,取了第一个字节的值赋值给另外一个内存的中间变量。
这是在干嘛呢?如果知道了业务逻辑,就清楚这个是在干嘛。这是在取tns数据的DataID,就是接收数据后,进行分析时的其中一步,保存DataID.