Модуль, позначений (F) в / proc / модулях


9

У моїй системі 3.10 деякі модулі, перелічені в / proc / модулі, позначені (F). Я хотів би знайти причину цього (F). Я впевнений, що модулі не завантажувались насильно і були побудовані за допомогою ядра. Не могли б ви вказати, який код ядра створює / proc / модулі?

usb_storage 56610 0 - Live 0xffffffffa005d000 (F)

Якщо я вивантажую та завантажую назад цей модуль, (F) пропадає.


Окрім коду (все ще шукаю цей біт), наступні найкращі ресурси, які я знайшов до цих пір, - це 2: unixhelp.ed.ac.uk/CGI/man-cgi?proc+5 & tldp.org/HOWTO/html_single/ Модуль-HOWTO . Це теж дещо корисно: centos.org/docs/5/html/Deployment_Guide-en-US/…
slm

Дякую слм. Ваш третій вказівник у розділі, що стосується / proc / модулів, пояснює шостий стовпець, який є зміщенням пам'яті. У ньому сказано, що цю інформацію використовують профілі - це моя проблема. Профілер мовчки відмовляється працювати, коли модуль позначений (F).
Стефан Т.

Відповіді:


11

Стовпці у висновку з /proc/modulesвигляду наступні.

usb_storage 56610 0    -   Live 0xffffffffa005d000 (F)
  (1)        (2) (3)  (4)  (5)         (6)         (7)

ПРИМІТКА. Я не знайшов згадки про те, що видається 7-м стовпцем, але я позначаю це як таке, оскільки описи 6-го стовпця (див. Нижче) не охоплюють інформацію, яка там відображається.

витяг - http://www.centos.org/docs/5/html/Deployment_Guide-en-US/s1-proc-topfiles.html

  • Перший стовпець містить назву модуля.
  • Другий стовпець посилається на розмір модуля пам'яті в байтах.
  • У третьому стовпці перераховано кількість завантажених зараз екземплярів модуля. Значення нуля являє собою завантажений модуль.
  • У четвертому стовпчику зазначено, що модуль залежить від іншого модуля, який повинен бути присутнім для функціонування, і перераховує ці інші модулі.
  • У п’ятому стовпці перераховано, у якому стані завантаження знаходиться модуль: Live, Loading або Unloading - єдино можливі значення.
  • У шостому стовпці перераховано поточний зсув пам'яті ядра для завантаженого модуля. Ця інформація може бути корисною для налагодження або для інструментів профілювання, таких як oprofile.

Я вважаю, що стовпець, який позначений (F)(тобто 7 стовпцем), походить звідси у цьому файлі - panic.c.

/**
 *  print_tainted - return a string to represent the kernel taint state.
 *
 *  'P' - Proprietary module has been loaded.
 *  'F' - Module has been forcibly loaded.
 *  'S' - SMP with CPUs not designed for SMP.
 *  'R' - User forced a module unload.
 *  'M' - System experienced a machine check exception.
 *  'B' - System has hit bad_page.
 *  'U' - Userspace-defined naughtiness.
 *  'D' - Kernel has oopsed before
 *  'A' - ACPI table overridden.
 *  'W' - Taint on warning.
 *  'C' - modules from drivers/staging are loaded.
 *  'I' - Working around severe firmware bug.
 *  'O' - Out-of-tree module has been loaded.
 *  'E' - Unsigned module has been loaded.
 *
 *  The string is overwritten by the next call to print_tainted().
 */

Ці коди є поданням для бітової маски, яка також присутня у kernel.txtдовідковій документації.

tainted:

 Non-zero if the kernel has been tainted.  Numeric values, which
 can be ORed together:

    1 - A module with a non-GPL license has been loaded, this
        includes modules with no license.
        Set by modutils >= 2.4.9 and module-init-tools.
    2 - A module was force loaded by insmod -f.
        Set by modutils >= 2.4.9 and module-init-tools.
    4 - Unsafe SMP processors: SMP with CPUs not designed for SMP.
    8 - A module was forcibly unloaded from the system by rmmod -f.
   16 - A hardware machine check error occurred on the system.
   32 - A bad page was discovered on the system.
   64 - The user has asked that the system be marked "tainted".  This
        could be because they are running software that directly modifies
        the hardware, or for other reasons.
  128 - The system has died.
  256 - The ACPI DSDT has been overridden with one supplied by the user
         instead of using the one provided by the hardware.
  512 - A kernel warning has occurred.
 1024 - A module from drivers/staging was loaded.
 2048 - The system is working around a severe firmware bug.
 4096 - An out-of-tree module has been loaded.
 8192 - An unsigned module has been loaded in a kernel supporting module
        signature.

Список літератури

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.