Модуль помечен (F) в / proc / modules

9

В моей системе 3.10 некоторые из модулей, перечисленных в / proc / modules, отмечены (F). Я хотел бы найти причину этого (F). Я уверен, что модули не были загружены принудительно и были собраны с ядром. Не могли бы вы указать, какой код ядра создает / proc / modules?

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/...
ОДС
Спасибо, СЛМ. Ваш третий указатель в разделе, ссылающемся на / proc / modules, объясняет шестой столбец, который является смещением памяти. Это говорит, что эта информация используется профилировщиками - это моя проблема. Профилировщик молча отказывается работать, когда модуль помечен (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», «Загрузка» или «Выгрузка».
  • В шестом столбце указано текущее смещение памяти ядра для загруженного модуля. Эта информация может быть полезна для целей отладки или для инструментов профилирования, таких как 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.

Ссылки

SLM
источник