15

我需要帮助来理解为什么我在插入模块时会出错。我试过这个没有成功。

$ sudo modprobe lpfc_scst 
FATAL: Error inserting lpfc_scst (/lib/modules/2.6.32-33-generic/extra/lpfc_scst.ko): Unknown symbol in module, or unknown parameter (see dmesg)

$ dmesg | tail
[ 1201.262842] lpfc_scst: Unknown symbol scst_register_target
[ 1201.262949] lpfc_scst: Unknown symbol lpfc_tm_term
[ 1201.263161] lpfc_scst: no symbol version for scst_register_session
[ 1201.263164] lpfc_scst: Unknown symbol scst_register_session
[ 1201.263284] lpfc_scst: no symbol version for scst_rx_mgmt_fn
[ 1201.263286] lpfc_scst: Unknown symbol scst_rx_mgmt_fn
[ 1201.263395] lpfc_scst: no symbol version for scst_unregister_session
[ 1201.263398] lpfc_scst: Unknown symbol scst_unregister_session
[ 1201.263573] lpfc_scst: no symbol version for scst_rx_data
[ 1201.263575] lpfc_scst: Unknown symbol scst_rx_data

$ cat /proc/kallsyms | grep scst_register_target
dffd2a10 r __ksymtab_scst_register_target   [scst]
dffd302e r __kstrtab_scst_register_target   [scst]
dffd2b34 r __kcrctab_scst_register_target   [scst]
dffd2a20 r __ksymtab___scst_register_target_template_non_gpl    [scst]
dffd3063 r __kstrtab___scst_register_target_template_non_gpl    [scst]
dffd2b3c r __kcrctab___scst_register_target_template_non_gpl    [scst]
dffd2c10 r __ksymtab___scst_register_target_template    [scst]
dffd308b r __kstrtab___scst_register_target_template    [scst]
dffd2de8 r __kcrctab___scst_register_target_template    [scst]
dff913a0 t __scst_register_target_template  [scst]
dff90dd0 T scst_register_target [scst]
dff91840 T __scst_register_target_template_non_gpl  [scst]

$

非常感谢。

4

3 回答 3

11

我已经按照这个论坛的建议解决了这个问题:

  1. 编译scst
  2. 将生成的附加Module.symvers到existent /lib/modules/<version>/build/Module.symvers哈克。不知道为什么内核没有看到导出的符号)。
  3. 复制scst/lib/modules/<version>/extra.
  4. depmod -a.
  5. 编译lpfc_scst
  6. 插入模块lpfc_scst没有问题。

祝你今天过得愉快。

于 2011-09-22T15:48:11.853 回答
3

如果您尝试插入一个针对不是正在运行的内核的实际源的内核源代码树/头文件构建的模块,最可能的原因是正在运行的内核和您构建的内核之间的某些内核配置不同。模块反对。

Linux 内核中的链接器实际上会查看除了符号名称之外的一堆东西来匹配符号,包括函数参数和返回值的哈希值、尝试匹配符号名称时的各种配置选项(抢占/非抢占)。我猜在您的情况下,由于配置选项不同,它找不到正确的匹配项

于 2011-09-22T13:20:09.167 回答
2

这意味着内核不允许模块看到该变量。看起来您还没有将变量添加到内核导出的符号列表中:

EXPORT_SYMBOL_NOVERS(scst_register_target);
于 2011-09-22T13:20:50.630 回答