行业解决方案查看所有行业解决方案
IDA 用于解决软件行业的关键问题。
发布时间:2023-09-17 09: 00: 00
IDA Pro 做为逆向工程领域必备工具,除了拥有强大的自身功能外,其开放的环境也为各类第三方提供了绝佳的插件开发支持,IDA Pro 官方每年都会举办面向全球开发者的插件大赛,评选出一二三等奖,并分享给所有IDA Pro的用户。
今天我们要分享的正是 2022 年插件大赛的二等奖得主,一款叫做 ida_kcpp 的插件。ida_kcpp 插件为 IDA 进行 iOS 内核缓存逆向工程提供有力的支持,在分析复杂的IOKit类时会非常的方便。
一、什么是ida_kcpp插件?
ida_kcpp 插件是一个用于更便捷地反向工程 iOS 内核缓存的 IDAPython 模块。
iOS 内核缓存的很大一部分是用 C++ 编写的,它编译成了复杂的二进制代码,使用了许多虚拟表解引用,而不是明确的直接调用。ida_kcpp 插件利用 ida_kernelcache 的类层次结构重建,它映射了 IDB 并同步了二进制函数和原始虚拟方法。ida_kcpp 插件允许通过双击 C++ 虚拟方法调用来导航 iOS 内核缓存,查找它们的交叉引用,并在实时研究过程中保持所有内容同步。
ida_kcpp 受 ida_medigate 启发,但由于 iOS 内核缓存的独特结构,它提供了更强大和方便的研究环境。
二、安装插件说明
ida_kcpp 插件安装步骤如下:
1. 先安装 ida_kernelcache ( Cellebrite 的分支版本)。
2. 确保 ida_kernelcache 和 ida_kcpp 位于 IDA Python 路径中。也可以通过将以下内容添加到 ~/.idapro/idapythonrc.py 中来实现:
import sys
sys.path.append(IDA_KCPP_PATH)
sys.path.append(IDA_KERNELCACHE_PATH)
3. 克隆存储库并创建符号链接,将 ~/.idapro/plugins/ida_kcpp_plugin.py 链接到 ida_kcpp_plugin.py。
4. 安装 ida-netnode。
5. [可选项]:如果需要反编译器结构字段的交叉引用跟踪,请安装 ida-referee 。
三、插件使用说明
ida_kcpp 插件使用方法在初步分析时的操作:
1. 打开要分析的内核缓存文件。如果尚未运行ida_kernelcache,请运行它:编辑(Edit) >> 插件(Plugins) >> 内核缓存CPP(Kernel Cache CPP) >> 处理内核(Process Kernel)。
2. 运行:编辑(Edit) >> 插件(Plugins) >> 内核缓存CPP(Kernel Cache CPP) >> 执行初始同步(Perform Initial sync)...(可能会出现一些警告对话框,暂时可以忽略)。此步骤将通过将前缀设置为所属类的类名来重命名虚拟函数的名称。它还反编译所有虚拟函数,设置它们的this参数,并将相关的::vmethods成员更改为对反编译类型的函数指针。这一步可能需要一些时间...
3. 现在有了一个“同步的IDB”,但请注意,插件尚未激活。
激活插件:
- 通过单击编辑(Edit) >> 插件(Plugins) >> 内核缓存CPP(Kernel Cache CPP) >> 激活插件(Activate Plugin)来激活ida_kcpp。这将安装Hexrays钩子并运行ida_kernelcache.collect_class_info()。
停用插件:
- 通过单击编辑(Edit) >> 插件(Plugins) >> 内核缓存CPP(Kernel Cache CPP) >> 停用插件(Deactivate Plugin)来停用插件。
四、IDA Pro官方的评价
如果您经常进行 iOS 内核缓存的逆向工程,这个插件几乎肯定会让您的生活变得更轻松。该插件利用了著名的 ida_kernelcache 插件提供的分析结果,并在其之上构建了一层便利工具。最显着的是,该插件使得在 C++ IOKit 类层次结构中的导航和函数重命名更加 "IOKit感知"。例如,当在 IOKit 类的 vtable 结构中重命名虚拟函数时,ida_kcpp 将自动重命名类层次结构中所有 vtable 结构中的成员,以及重命名函数本身。这在构建复杂的 IOKit 类的分析时非常方便,这些类可能有数十个超类/子类,每个都有自己实现相同虚拟函数的方式。自动化这样的任务并不是微不足道的,但该插件在用户的最小努力下提供了这个功能,做得非常好。
下载ida_kcpp插件请点击下方【下载完整资料】按钮
展开阅读全文
︾
读者也喜欢这些内容:
ppc反汇编怎么看 IDA如何分析ppc反汇编
通过PPC反汇编技术,开发者能够将复杂的机器码转换为易于理解的汇编指令,从而更好地分析程序的功能和执行过程。在接下来的部分中,我们将探讨ppc反汇编怎么看,IDA如何分析ppc反汇编,为您展示如何深入挖掘程序的内部机制。...
阅读全文 >
IDA Pro 2022插件大赛三等奖:FindFunc插件下载
IDA官方插件大赛2022年,二等奖获得者是一款叫做FindFunc的插件,它提供了一种简单的方法来搜索和维护与规则列表(包括代码模式和字节模式)相对应的函数列表。...
阅读全文 >
IDA Pro 2022插件大赛一等奖:ttddbg插件下载
IDA Pro 做为逆向工程领域必备工具,除了拥有强大的自身功能外,其开放的环境也为各类第三方提供了绝佳的插件开发支持,IDA Pro官方每年都会举办面向全球开发者的插件大赛,评选出一二三等奖,并分享给所有IDA Pro的用户。今天的插件就是2022年一等奖作品。...
阅读全文 >
利用插件为IDA设置不同主题
在上一节《IDA颜色相关的配置及其导入导出》中,我们主要了解如何在IDA中进行颜色的设置,以让我们选择更适合自己使用的颜色配色。在本文中我将继续以此为目的,讲解如何通过插件的形式,为IDA软件设置不同的主题。...
阅读全文 >