gpt4 book ai didi

macos - 在多个不同的内核模块(驱动程序)之间进行通信

转载 作者:行者123 更新时间:2023-12-04 03:07:17 25 4
gpt4 key购买 nike

为了实现更好的封装和模块化,我决定将我的内核驱动程序拆分为 2 个(可以更多)模块,每个模块负责不同的功能。

但是,仍然有一些数据+逻辑我想在这些模块之间共享(即一个模块可以管理与用户空间的通信,而另一个使用它作为中介)我想知道是否有任何简单的方法这样做的方法。

例如,我想将一些 API 从一个模块发布到另一个模块,这是绝对可行的,因为两个模块都在内核进程下运行,并且映射到同一地址空间中的不同范围。

问题是每个内核模块都有自己的符号表,为了发布 API,需要某种加载程序来修复寻址/指针等。这就像调用 dlopendlsym 在与库动态链接时来自用户空间,但在内核空间中并且每个库还拥有状态(由其所有内部堆/全局参数的当前快照定义的状态)。

我的问题是这种方法在 macOS 领域是否有效并被接受?

编辑,在下面question ,它解释了实现我的目标的 linux 方式,也许你知道在 macOS/XNU 中什么是 symbol_getsymbol_put 的等价物?

最佳答案

Linux 方面好像已经在评论里回答过了。

对于 macOS kexts,使用的机制是 OSBundleLibraries and OSBundleCompatibleVersion Info.plist properties. kext exporting 符号必须设置 OSBundleCompatibleVersion 属性。这必须小于或等于其 CFBundleVersion 并允许您对 API 进行版本控制。

希望导入其他 kext 符号的 kext 必须在 OSBundleLibraries 字典中列出导出 kext 的包标识符,以及适当的版本数。

请注意,链接到另一个 kext 将导入 所有 它的公共(public)符号,因此我强烈建议将所有符号默认隐藏并提供一个显式导出文件。为此,在 Xcode 目标设置中启用“默认隐藏的符号”,创建一个新的 .exp(或 .exports)文件,并在“导出的符号文件”设置中声明它。至少,您需要将 _kmod_info 添加到此文件。然后添加您希望导出的所有符号,每行一个。

C 函数和全局变量需要使用下划线作为前缀,C++ 函数和静态类成员变量需要以通常的方式进行修饰。您可以将 * 用作(部分)通配符,例如,对于具有大量成员函数的 C++ 类,这有时很方便。如果您需要引用,xnu 源代码分发包含大量导出文件示例。您可以使用 nm 工具生成您的 kext 中所有符号的列表,然后您可以从中挑选;这使您免于手动修改名称。

Kexts 不能相互循环依赖。一个需要是“图书馆”,另一个是该图书馆的“用户”。如果他们需要交互,你将需要使用回调、虚函数等。

“库”kext 必须安装在/Library/Extensions(在 OS X 10.8 或更早版本上为/System/Library/Extensions),否则库的用户将找不到它,可能即使库 kext 已经加载。 如果您的“用户”kext 在其 OSBundleRequired 属性中指定本地或网络启动可能需要它,则它所依赖的库应该声明相同条件或这些条件的超集,否则它们可能不会被适本地预链接/kextcached。

Apple 确实有少量 documentation on designing kext libraries也是。

关于macos - 在多个不同的内核模块(驱动程序)之间进行通信,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47755233/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com