Linux 内核模块检查内存完整性

发布于 2024-12-02 05:14:27 字数 292 浏览 6 评论 0原文

我正在编写一个内核模块,它通过控制校验和来检查正在运行的任务的代码段的完整性。我遇到了一些障碍:

  1. 如果 module_list 变量不是由内核导出的(ksyms 中没有这样的符号),我如何获取它?我可以看到所有调用 lsmod 命令的模块,那么如何在我的模块中获取它呢?
  2. 当我的模块运行时,它显示一些代码段已被更改。某些库总是会发生这种情况。为什么会发生这种情况?我认为代码段是不变的。
  3. 控制内核模块中进程数据的内存访问是否可行?如何实现?

I'm writing a kernel module that checks the integrity of code segments for running tasks by controlling checksums. I ran into a few hurdles:

  1. How can I get the module_list variable if it isn't exported by the kernel (there is no such symbol in ksyms)? I can see all modules calling the lsmod command, so how can I get it in my module?
  2. While my module is running it shows that some code segments have been changed. It always happens with certain libraries. Why does it happen? I thought that code segments were constant.
  3. Is it feasible to control memory access for process data from a kernel module and how to do it?

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

玩世 2024-12-09 05:14:27

完全支持自修改代码。没什么毛病,各种东西都用它。您关于代码恒定的假设根本不正确。可能是,但也可能不是。

一个典型的例子是 SMP 与 UP 系统。例如,在 Pentium 4 级 Xeon 机器上,解锁增量可以比锁定增量少 60 个周期。仅在 SMP 机器上需要锁定增量。为了使相同的代码在 UP 和 SMP 机器上工作而没有运行时条件的开销,通常使用自修改代码。使用ud2 等非法操作码代替lock 指令。非法指令中断被捕获,ud2 在 SMP 系统上被 lock 替换,在 UP 系统上被 nop 替换。

内核导出一个模块接口。导出的是:

__module_text_address __symbol_get symbol_put_addr use_module
module_layout module_put __module_put_and_exit module_refcount 
register_module_notifier __symbol_put unregister_module_notifier module_get 

如果您确实愿意,您还可以解析 /proc/modules

Self-modifying code is fully supported. There is nothing wrong with it, and it is used for all kinds of things. Your assumption that code is constant is simply not correct. It may be, but it may not be.

One typical example is in SMP versus UP systems. On Pentium 4 class Xeon machines, for example, an unlocked increment can take 60 cycles fewer than a locked increment. The locked increment is needed only on SMP machines. To make the same code work on both UP and SMP machines without the overhead of a condition at run time, self-modifying code is typically used. In the place of the lock instruction, an illegal opcode such as ud2 is used. The illegal instruction interrupt is caught and the ud2 is replaced by lock on an SMP system and nop on a UP system.

The kernel exports a module interface. Exported are:

__module_text_address __symbol_get symbol_put_addr use_module
module_layout module_put __module_put_and_exit module_refcount 
register_module_notifier __symbol_put unregister_module_notifier module_get 

You could also parse /proc/modules if you really wanted to.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文