Неизвестный символ при загрузке модуля ядра
Мне нужна помощь, чтобы понять, почему я получаю сообщение об ошибке при вставке модуля. Я пробовал этот без успеха.
$ 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]
$
Большое спасибо.
Ответы
Ответ 1
Я решил эту проблему, как предложено на этом форуме:
- Скомпилированный
scst
.
- Добавил сгенерированный
Module.symvers
в существующий /lib/modules/<version>/build/Module.symvers
(Hack. Не знаю, почему ядро не отображало экспортированные символы).
- Скопировано
scst
в /lib/modules/<version>/extra
.
-
depmod -a
.
- Скомпилировано
lpfc_scst
.
- Вставить модуль
lpfc_scst
без проблем.
Хороший день.
Ответ 2
Это означает, что ядро не позволяет модулям видеть эту переменную. Похоже, вы не добавили свои переменные в список символов, которые экспортирует ядро:
EXPORT_SYMBOL_NOVERS(scst_register_target);
Ответ 3
Если вы пытаетесь внедрить модуль, который был создан против исходного дерева/заголовков ядра, которые не являются фактическим источником работающего ядра, наиболее вероятной причиной является то, что некоторая конфигурация ядра отличается от используемого ядра и того, вы построили модуль против.
Компилятор внутри ядра Linux фактически просматривает кучу вещей, помимо имени символа для сопоставления символов, включая, возможно, хэш параметра функции и возвращаемого значения, различные параметры конфигурации (preempt/non preempt) при попытке сопоставить символ имена. Я предполагаю, что в вашем случае он не находит правильное совпадение из-за разных параметров конфигурации.