Неизвестный символ во время загрузки модуля ядра - PullRequest
14 голосов
/ 22 сентября 2011

Мне нужна помощь, чтобы понять, почему я получаю сообщение об ошибке при установке модуля.Я попытался это безуспешно.

$ 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]

$

Большое спасибо.

Ответы [ 3 ]

10 голосов
/ 22 сентября 2011

Я решил эту проблему, как предложено на этом форуме :

  1. Скомпилировано scst.
  2. Добавил сгенерированный Module.symvers к существующему /lib/modules/<version>/build/Module.symvers ( Hack. Не знаю, почему ядро ​​не увидело экспортированные символы ).
  3. Скопировал scst в /lib/modules/<version>/extra.
  4. depmod -a.
  5. Скомпилировано lpfc_scst.
  6. Вставленный модуль lpfc_scst без проблем.

Хорошего дня.

2 голосов
/ 22 сентября 2011

Это означает, что ядро ​​не позволяет модулям видеть эту переменную.Похоже, вы не добавили переменные в список символов, экспортируемых ядром:

EXPORT_SYMBOL_NOVERS(scst_register_target);
1 голос
/ 22 сентября 2011

Если вы пытаетесь выполнить insmod для модуля, который был собран из дерева / заголовков исходного кода ядра, которые не являются фактическим источником работающего ядра, наиболее вероятная причина заключается в том, что некоторые конфигурации ядра отличаются между работающим ядром и Вы построили модуль против.

Компоновщик в ядре Linux на самом деле рассматривает множество вещей, помимо имени символа для совпадающих символов, включая, возможно, хэш параметра функции и возвращаемого значения, различные параметры конфигурации (preempt / non preempt) при попытке сопоставления символа имена. Я думаю, что в вашем случае он не находит правильного соответствия из-за различных параметров конфигурации

...