query_module - запросить ядро о различных параметрах, касающихся модулей
query_module(2)
запросить ядро о различных параметрах, касающихся модулей
ОБЗОР
#include <linux/module.h>
int query_module(const char *name, int which, void *buf,
size_t bufsize, size_t *ret);
Замечание: В заголовочных файлах glibc эта функция отсутствует; смотрите
ЗАМЕЧАНИЯ.
ОПИСАНИЕ
Замечание: Данный системный вызов доступен только в ядрах до Linux 2.6.
query_module() запрашивает информацию у ядра о загружаемых
модулях. Возвращаемая информация помещается в буфер, указанный в
buf. Вызывающий должен указать размер buf в bufsize. Смысл и формат
возвращаемой информации зависит от операции, задаваемой в which. Для
некоторых операций требуется заполнить name для указания на уже
загруженный модуль, для некоторых в name можно указать NULL, что
указывает на получения свойства ядра.
В which можно указать следующие значения:
0
Завершается успешно, если ядро поддерживает query_module(). Используется
для проверки доступности системного вызова.
QM_MODULES
Возвращает имена всех загруженных модулей. Возвращаемый буфер содержит
последовательность строк, оканчивающихся null; в ret указано количество
модулей.
QM_DEPS
Возвращает имена всех модулей, используемых указанным модулем. Возвращаемый
буфер содержит последовательность строк, оканчивающихся null; в ret
указано количество модулей.
QM_REFS
Возвращает имена всех модулей, использующих указанный модуль. Это обратная
по отношению к QM_DEPS операция. Возвращаемый буфер содержит
последовательность строк, оканчивающихся null; в ret указано количество
модулей.
QM_SYMBOLS
Возвращает символы и значения, экспортируемые ядром или указанным
модулем. Возвращаемый буфер содержит массив структур следующего формата:
struct module_symbol {
unsigned long value;
unsigned long name;
};
завершаемого строками, оканчивающимися null. Значение
name содержит
смещение строки в знаках относительно начала
buf; в
ret указано
количество символов.
QM_INFO
Возвращает различную информацию об указанном модуле. Формат результата в
буфере:
struct module_info {
unsigned long address;
unsigned long size;
unsigned long flags;
};
где
address — это адрес ядра, где располагается модуль,
size — размер
модуля в байтах,
flags — маска
MOD_RUNNING,
MOD_AUTOCLEAN и т. п.,
показывающая текущее состояние модуля (смотрите файл исходного кода ядра
Linux
include/linux/module.h). В
ret указан размер структуры
module_info.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ
При успешном выполнении возвращается ноль. В случае ошибки возвращается -1,
а
errno устанавливается в соответствующее значение.
ОШИБКИ
EFAULT
Одно из значений в name, buf или ret находится вне доступного
программного адресного пространства.
EINVAL
Неправильное значение which; name равно NULL (указывающее "параметры
ядра"), но оно не разрешено для указанного значения which.
ENOENT
Модуль с именем, указанным в name, не существует.
ENOSPC
Указанный размер буфера слишком мал. В ret возвращается минимальный
необходимый размер.
ENOSYS
query_module() не поддерживается в этой версии ядра (например, в 2.6 или
более поздних).
ВЕРСИИ
Данный системный вызов есть только в Linux до версии 2.4; он был удалён в
Linux 2.6.
СООТВЕТСТВИЕ СТАНДАРТАМ
query_module() есть только в Linux.
ЗАМЕЧАНИЯ
Некоторую информацию, которая была ранее доступна через
query_module(),
можно получить из
/proc/modules,
/proc/kallsyms и файлов из каталога
/sys/modules.
Системный вызов query_module() не поддерживается glibc. В заголовочных
файлах glibc он не объявлен, но в недавнем прошлом glibc экспортировал ABI
для этого системного вызова. Поэтому чтобы получить данный системный вызов
достаточно вручную объявить интерфейс в своём коде; или же вы можете вызвать
его через syscall(2).