query_module(2) System Calls Manual query_module(2) NOM query_module - Interroger le noyau sur diverses choses relatives aux modules SYNOPSIS #include [[obsolete]] int query_module(const char *name, int which, void buf[.bufsize], size_t bufsize, size_t *ret); DESCRIPTION Remarque : cet appel systeme n'est present qu'avant Linux 2.6. query_module() demande au noyau des informations sur les modules chargeables. L'information renvoyee est placee dans un tampon pointe par buf. L'appelant doit indiquer la taille de buf dans bufsize. La nature precise et le format de l'information renvoyee dependent de l'operation qui a ete specifiee dans which. Certaines operations necessitent un name pour identifier un module actuellement charge, d'autres permettent que name soit NULL, indiquant le noyau. which peut prendre les valeurs suivantes : 0 Retourner avec succes si le noyau prend en charge query_module(). Utilise pour tester la disponibilite de l'appel systeme. QM_MODULES Renvoyer les noms de tous les modules charges. Le tampon renvoye consiste en une sequence de chaines de caracteres terminees par un octet nul ; ret prend la valeur du nombre de modules. QM_DEPS Renvoyer le nom de tous les modules utilises par le module indique. Le tampon renvoye consiste en une sequence de chaines de caracteres terminees par un octet nul ; ret prend la valeur du nombre de modules. QM_REFS Renvoyer le nom de tous les modules utilisant le module indique. C'est l'inverse de QM_DEPS. Le tampon renvoye consiste en une sequence de chaines de caracteres terminees par un octet nul ; ret prend la valeur du nombre de modules. QM_SYMBOLS Renvoyer les symboles et valeurs exportes par le noyau ou le module indique. Le tampon renvoye est un tableau de structures de la forme suivante : struct module_symbol { unsigned long value; unsigned long name; }; suivi par des chaines de caracteres terminees par un octet nul. La valeur de name est le decalage en caractere de la chaine relativement au debut de buf ; ret prend la valeur du nombre de symboles. QM_INFO Renvoyer diverses informations sur le module indique. Le format du tampon de sortie est de la forme : struct module_info { unsigned long address; unsigned long size; unsigned long flags; }; ou address est l'adresse noyau ou se trouve le module, size est la taille en octets du module et flags un masque de MOD_RUNNING, MOD_AUTOCLEAN, etc., qui indique l'etat actuel du module (consultez le fichier include/linux/module.h dans les sources du noyau Linux). ret prend la valeur de la taille de la structure module_info. VALEUR RENVOYEE En cas de succes, 0 est renvoye. en cas d'echec, -1 est renvoye et errno se positionne pour indiquer l'erreur. ERREURS EFAULT Au moins une adresse parmi name, buf ou ret est en dehors de l'espace d'adressage accessible du programme. EINVAL which est invalide ou name est NULL (indiquant le noyau) mais ce n'est pas permis avec la valeur de which. ENOENT Aucun module du nom name n'existe. ENOSPC La taille du tampon fournie est trop petite ; ret prend la valeur de la taille minimum necessaire. ENOSYS query_module() n'est pas pris en charge par cette version du noyau (par exemple, Linux 2.6 ou au-dela). STANDARDS Linux. VERSIONS Supprime dans Linux 2.6 Certains renseignements, qui etaient auparavant disponibles avec query_module(), peuvent etre obtenus dans /proc/modules, /proc/kallsyms et les fichiers du repertoire /sys/modules. L'appel systeme query_module() n'est pas pris en charge par la glibc. Il n'est pas declare dans les en-tetes de la glibc, mais par un caprice de l'histoire, la glibc fournit une interface binaire pour cet appel systeme. Ainsi, il suffit de declarer manuellement l'interface dans votre code pour utiliser cet appel systeme. Sinon, vous pouvez l'invoquer en utilisant syscall(2). VOIR AUSSI create_module(2), delete_module(2), get_kernel_syms(2), init_module(2), lsmod(8), modinfo(8) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot et Thomas Vincent Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 query_module(2)