gpt4 book ai didi

linux - 尝试插入访问导出符号的模块时出现 "Invalid parameters"错误

转载 作者:IT王子 更新时间:2023-10-29 00:18:12 27 4
gpt4 key购买 nike

我试图在两个模块之间共享一个全局变量,以便了解如何正确使用 EXPORT_SYMBOL 宏,但我总是收到 Invalid paramaters 错误我尝试插入第二个模块。

在第一个模块foo.c中:

#include <linux/module.h>
#include <linux/kernel.h>

extern unsigned myvar;
unsigned myvar = 42;
EXPORT_SYMBOL(myvar);

static int __init foo_init(void){
printk(KERN_INFO "HELLO FROM MODULE 1");

return 0;
}

static void __exit foo_exit(void){
printk(KERN_INFO "BYE FROM MODULE 1");
}

module_init(foo_init);
module_exit(foo_exit);

MODULE_LICENSE("GPL");

在第二个模块bar.c中:

#include <linux/module.h>
#include <linux/kernel.h>

extern unsigned myvar;

static int __init bar_init(void){
printk(KERN_INFO "HELLO FROM MODULE 2");

printk(KERN_INFO "myvar: %u", myvar);

return 0;
}

static void __exit bar_exit(void){
printk(KERN_INFO "BYE FROM MODULE 2");
}

module_init(bar_init);
module_exit(bar_exit);

MODULE_LICENSE("GPL");

我使用单独的 Makefile 在单独的目录中编译每个模块。然后我手动插入每个模块:

# insmod foo.ko
# insmod bar.ko

Error: could not insert module bar.ko: Invalid parameters

如果我首先尝试插入 bar.ko,我会收到预期的未知符号错误:

# insmod bar.ko
Error: could not insert module bar.ko: Unknown symbol in module

这是符号转储:

# nm foo.ko | grep myvar

00000000ec933bae A __crc_myvar
0000000000001118 r __kcrctab_myvar
000000000000057c r __kstrtab_myvar
0000000000000b20 r __ksymtab_myvar
0000000000000180 D myvar

我正在运行一个应用了 Xenomai 补丁的 Debian 系统(内核 v3.2.21):

# uname -r
3.2.21-xenomai-2.6.2.1-ipipe

不幸的是,我不认为CONFIG_KALLSYMS_ALL已启用,因此我无法查看 /proc/kallsyms/ 以验证 myvar 是否已实际导出。

最佳答案

我决定四处查看系统以找出错误的原因:

# dmesg | tail
[11169.107152] HELLO FROM MODULE 1
[11226.101245] bar: no symbol version for myvar
[11226.101254] bar: Unknown symbol myvar (err -22)

看起来问题不在于导出符号,而是考虑符号版本

解决方案详见Documentation/kbuild/modules.txt并且非常简单:确保该符号在 Module.symvers 文件中有一个条目。


例如,在我的例子中,两个模块分别位于 /home/vilhelm/foo//home/vilhelm/bar/。由于我分别编译每个模块,因此每个目录都有自己的 Makefile。首先,我在 foo 目录中执行 make 以在该目录中为 foo 模块生成 Module.symvers 文件.

# make

接下来,我修改了 bar 模块的 Makefile,方法是在 Makefile 的顶部插入以下行:

KBUILD_EXTRA_SYMBOLS := /home/vilhelm/foo/Module.symvers

注意这是绝对路径!

最后我在 bar 目录中执行 make 并手动插入模块:

# make

...

# insmod /home/vilhelm/foo/foo.ko
# insmod /home/vilhelm/bar/bar.ko

没有错误,这是一个好兆头。

现在是关键时刻:

# dmesg | tail
[12675.200451] HELLO FROM MODULE 1
[12715.743320] HELLO FROM MODULE 2
[12715.743328] myvar: 42

成功了! :-)

关于linux - 尝试插入访问导出符号的模块时出现 "Invalid parameters"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16360689/

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