Last updated
Last updated
在上一篇文章中我们介绍了 IDA 中的选择操作的基本用法。这周我们将介绍一些选择操作相关的例子。
当反汇编一个原始二进制文件时,IDA 并不总是可以检测出代码片段,你必须得使用试错法来在整个加载范围中查找代码片段,这可能是一个耗时的过程。在这种情况下,下面的方法可用来做初始化的分析:
使用快捷键定位到数据库起始地址(Ctrl
–PgUp
);
开始选择(Alt
–L
);
直到结束(Ctrl
–PgDn
)。你也可以选择到具体的某一个地方,如果你认为这个地方是代码块结束的地方的话(例如:一大块 \x00
或 \xFF
字节前面的地方);
选择“Edit->Code”或者按下 c
,会出现一个会话框询问你要做什么具体操作:
如果你确定在选择的区间内确实存在大量指令的话就点击“Force”,如果在指令间可能存在数据的话就点击“Analyze”。
IDA 会遍历选择的区域并且尝试将任何未定义的字节转换为指令。如果在选择区域确实存在合法代码,你可能会看到一些函数被添加到函数窗口中去(可能会包括一些误报)。
选择操作的另外一个有用的用法是将结构体便宜应用到多条指令中去。举个例子,我们来看看 UEFI 模块中的这个函数:
如果我们知道 gBS
是指向 EFI_BOOT_SERVICES
的一个指针,我们可以将对它的访问(在 call 指令中)转换为结构体的偏移。这可以通过手工对每个访问进行转换来完成,但却很繁琐。这种情况下选择操作会很有用。如果我们选择了访问结构体的这些指令然后按下 T
(structure offset),会弹出一个新的会话框:
你可以选择哪一个寄存器用作基址,哪一个结构体将会被应用,甚至可以选择你想转换哪一条具体的指令。
选择了 rax
和 EFI_BOOT_SERVICES
之后,我们会得到一个好看的列表:
当一些代码引用一个字符串时,IDA 通常足够聪明,能够检测到它并将引用的字节转换为文字项。然而,在某些情况下,自动转换不起作用,例如:
字符串包括非 ASCII 字符
字符串不是以 null 字节结尾的
第一种情况的一个常见示例是 Linux 内核,它使用特殊的字节序列来标记不同类别的内核消息。例如,joydev.ko
模块中的这个函数:
IDA 不会在 1BC8
处自动创建一个字符串,因为它是以非 ASCII 字符开头的。然而,如果我们选择了字符串的字节然后按下 A
(Convert to string),无论如何字符串都会被创建:
处理二进制文件中的结构化数据时,此操作也非常有用。让我们考虑一个具有大致如下条目布局的表:
虽然这种结构总是可以在 Structures 窗口中手动创建,但通常需要先格式化数据,然后创建描述数据的结构才会更容易。创建四个数据项后,选择它们,并从上下文菜单中选择“Create struct from selection”:
IDA 将创建一个表示所选数据项的结构,然后可用于格式化程序或反汇编中的其他条目,以更好地理解处理这些数据的代码。
via: https://hex-rays.com/blog/igor-tip-of-the-week-04-more-selection/
作者:Igor Skochinsky 译者: 校对: