Provided by: manpages-fr-dev_4.27.0-1_all bug

NOM

       if_nameindex, if_freenameindex - Obtenir le nom et l'indice des interfaces réseau

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <net/if.h>

       struct if_nameindex *if_nameindex(void);
       void if_freenameindex(struct if_nameindex *ptr);

DESCRIPTION

       La  fonction  if_nameindex()  renvoie  un  tableau  de  structures  if_nameindex,  contenant  chacune des
       informations au sujet d'une des interfaces réseau du système local. La structure if_nameindex contient au
       moins les champs suivants :

           unsigned int if_index; /* Indice de l'interface (1, 2, etc.) */
           char        *if_name;  /* nom se terminant par un caractère nul ("eth0", etc.) */

       Le champ if_index contient l'indice de l'interface. Le champ ifa_name pointe vers le nom  de  l'interface
       qui  se  termine  par  un  caractère  nul.  La fin du tableau est indiquée par une entrée dont les champs
       if_index et ifa_name valent respectivement 0 et le pointeur NULL.

       La  donnée  renvoyée  par  if_nameindex()  est  dynamiquement  allouée  et  devrait  être  libérée   avec
       if_freenameindex() lorsqu'elle n'est plus utilisée.

VALEUR RENVOYÉE

       En  cas de réussite, if_nameindex() renvoie un pointeur vers le tableau. En cas d'erreur, elle renvoie un
       pointeur NULL et errno est positionné pour indiquer l'erreur.

ERREURS

       if_nameindex() peut échouer et remplir errno si :

       ENOBUFS
              les ressources disponibles sont insuffisantes.

       getifaddrs()  peut aussi échouer  pour les erreurs précisées  pour  socket(2),  bind(2),  getsockname(2),
       recvmsg(2), sendto(2) ou malloc(3).

ATTRIBUTS

       Pour une explication des termes utilisés dans cette section, consulter attributes(7).
       ┌──────────────────────────────────────────────────────────────────────┬──────────────────────┬─────────┐
       │ InterfaceAttributValeur  │
       ├──────────────────────────────────────────────────────────────────────┼──────────────────────┼─────────┤
       │ if_nameindex(), if_freenameindex()                                   │ Sécurité des threads │ MT-Safe │
       └──────────────────────────────────────────────────────────────────────┴──────────────────────┴─────────┘

STANDARDS

       POSIX.1-2008, RFC 3493.

HISTORIQUE

       glibc 2.1. POSIX.1-2001. BSDi.

       Les  versions  antérieures  à  la  glibc  2.3.4 ne géraient que les interfaces avec des adresses IPv4. La
       gestion des interfaces qui n'ont pas d'adresse IPv4 n'est disponible que si le noyau gère netlink.

EXEMPLES

       Le programme ci-dessous montre l'utilisation des fonctions décrites dans cette page. Voici un exemple  de
       sortie que ce programme peut produire :

           $ ./a.out 1: lo 2: wlan0 3: em1

   Source du programme
       #include <net/if.h>
       #include <stdio.h>
       #include <stdlib.h>
       #include <unistd.h>

       int
       main(void)
       {
           struct if_nameindex *if_ni, *i;

           if_ni = if_nameindex();
           if (if_ni == NULL) {
               perror(
               exit(EXIT_FAILURE);
           }

           for (i = if_ni; !(i->if_index == 0 && i->if_name == NULL); i++)
               printf("%u : %s\n", i->if_index, i->if_name);

           if_freenameindex(if_ni);

           exit(EXIT_SUCCESS);
       }

VOIR AUSSI

       getsockopt(2), setsockopt(2), getifaddrs(3), if_indextoname(3), if_nametoindex(3), ifconfig(8)

TRADUCTION

       La   traduction   française   de   cette   page   de   manuel   a   été   créée   par  Christophe  Blaess
       <https://www.blaess.fr/christophe/>,   Stéphan   Rafin   <stephan.rafin@laposte.net>,   Thierry   Vignaud
       <tvignaud@mandriva.com>,  François  Micaux,  Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard
       <fevrier@tigreraye.org>,   Jean-Luc   Coulon   (f5ibh)   <jean-luc.coulon@wanadoo.fr>,   Julien   Cristau
       <jcristau@debian.org>,      Thomas      Huriaux      <thomas.huriaux@gmail.com>,     Nicolas     François
       <nicolas.francois@centraliens.net>,    Florentin    Duneau    <fduneau@gmail.com>,     Simon     Paillard
       <simon.paillard@resel.enst-bretagne.fr>,     Denis    Barbier    <barbier@debian.org>,    David    Prévot
       <david@tilapin.org>,    Cédric    Boutillier     <cedric.boutillier@gmail.com>,     Frédéric     Hantrais
       <fhantrais@gmail.com> et Jean-Philippe MENGUAL <jpmengual@debian.org>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General Public License
       version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

       Si vous découvrez un bogue dans la traduction de cette page de manuel,  veuillez  envoyer  un  message  à
       debian-l10n-french@lists.debian.org.

Pages du manuel de Linux 6.9.1                    15 juin 2024                                   if_nameindex(3)