返回介绍

18.5 其他加载器策略

发布于 2024-10-11 21:05:47 字数 1059 浏览 0 评论 0 收藏 0

如果花一些时间浏览 SDK 中的示例加载器,你将发现各种不同风格的加载器。Java 加载器(<SDKDIR>/ldr/javaldr)值得注意。对于某些文件格式来说,加载器与处理器模板之间的耦合非常松散。一旦加载器发现进入代码的入口点,处理器模块不需要其他信息,就能够正确反汇编这些代码。一些处理器模块可能需要大量与最初的源文件有关的信息,并且必须执行之前已经由加载器完成的许多解析任务。为了避免这种重复工作,加载器和处理器可能会以一种更加紧密耦合的方式配对。实际上,Java 加载器所采取的方法就是使用以下代码,将所有加载任务(那些通常由加载器的 load_file 函数完成的任务)交给处理器模块:

static void load_file(linput_t *li, ushort neflag, const char *) {  
  if (ph.id != PLFM_JAVA) {  
    set_processor_type("java", SETPROC_ALL | SETPROC_FATAL);  
  }  
  if (ph.notify(ph.loader, li, (bool)(neflag & NEF_LOPT))) {  
    error("Internal error in loader<->module link");  
  }  
}

Java 加载器所做的唯一一件工作是确定处理器类型已被设置为 Java 处理器,之后,加载器将向处理器模块发送一条 ph.loader (在 idp.hpp 中定义)通知消息,告诉处理器加载阶段已经启动。收到通知后,Java 处理器将接管加载任务,并在这个过程中获得大量内部状态信息。在执行反汇编任务时,处理器将重用这些信息。

这种策略是否对你有用,完全取决于你是否正开发加载器及相关的处理器模块,以及你是否认为处理器能够得益于访问传统上由加载器获取的信息(分段、文件头字段、调试信息等)。

由加载器向处理器模块传递状态信息的另一种方法是使用数据库网络节点。在加载阶段,加载器可能会在特定的网络节点中填入一些信息,供处理器模块在随后的反汇编阶段检索使用。需要注意的是,频繁访问数据库,以检索以这种方式存储的信息,其速度要比利用可用的 C++ 数据类型慢一些。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文