Man page - packet(7)

Packages contains this manual

Available languages:

en fr ja ru zh_TW zh_CN

Manual

packet

NOM
SYNOPSIS
DESCRIPTION
Types d’adresses
Options de socket
Ioctls
Traitement des erreurs
ERREURS
VERSIONS
NOTES
Compatibilité
BOGUES
Gestion des en-tĂȘtes LLC
ProblĂšmes avec MSG_TRUNC
spkt_device device name truncation
ProblĂšmes de documentation
VOIR AUSSI
TRADUCTION

NOM

packet – Interface de paquets au niveau du pĂ©riphĂ©rique

SYNOPSIS

#include <sys/socket.h>
#include <linux/if_packet.h>
#include <net/ethernet.h> /* Les protocoles L2 */

packet_socket = socket(AF_PACKET, int type_socket , int protocole );

DESCRIPTION

Les sockets packet sont utilisĂ©s pour envoyer ou recevoir des paquets bruts au pilote de pĂ©riphĂ©rique (couche 2 OSI). Ils permettent d’implĂ©menter des modules de protocole dans l’espace utilisateur au-dessus de la couche physique.

The socket_type is either SOCK_RAW for raw packets including the link-level header or SOCK_DGRAM for cooked packets with the link-level header removed. The link-level header information is available in a common format in a sockaddr_ll structure. protocol is the IEEE 802.3 protocol number in network byte order. See the <linux/if_ether.h> include file for a list of allowed protocols. When protocol is set to htons(ETH_P_ALL) , then all protocols are received. All incoming packets of that protocol type will be passed to the packet socket before they are passed to the protocols implemented in the kernel. If protocol is set to zero, no packets are received. bind (2) can optionally be called with a nonzero sll_protocol to start receiving packets for the protocols specified.

Pour pouvoir crĂ©er des sockets packet, un processus doit possĂ©der la capacitĂ© CAP_NET_RAW dans l’espace de noms utilisateur qui rĂ©git son espace de noms rĂ©seau.

Les paquets SOCK_RAW sont transmis depuis et vers le pilote de pĂ©riphĂ©rique sans aucune modification des donnĂ©es des paquets. Lors de la rĂ©ception d’un paquet, l’adresse est toujours examinĂ©e et fournie dans une structure standard d’adresse sockaddr_ll . Lors de l’émission d’un paquet, le tampon fourni par l’utilisateur doit contenir l’en-tĂȘte de couche physique. Le paquet est alors mis en attente sans modification Ă  l’attention du pilote de pĂ©riphĂ©rique correspondant Ă  l’interface dĂ©finie par l’adresse de destination. Certains pilotes de pĂ©riphĂ©rique ajoutent toujours d’autres en-tĂȘtes. SOCK_RAW est similaire mais non compatible avec l’ancien AF_INET/SOCK_PACKET de Linux 2.0.

SOCK_DGRAM opĂšre Ă  un niveau lĂ©gĂšrement plus Ă©levĂ©. L’en-tĂȘte de couche physique est supprimĂ© avant que le paquet ne soit transmis Ă  l’utilisateur. Les paquets envoyĂ©s par un socket packet SOCK_DGRAM reçoivent un en-tĂȘte de couche physique correct basĂ© sur les informations dans l’adresse destination sockaddr_ll avant d’ĂȘtre mis en attente.

Par dĂ©faut, tous les paquets du type de protocole indiquĂ© sont passĂ©s au socket packet. Pour ne recevoir que les paquets d’une interface donnĂ©e, utilisez bind (2) en indiquant une adresse dans une struct sockaddr_ll pour attacher le socket Ă  une interface. Les champs utilisĂ©s pour la liaison sont sll_family (devrait ĂȘtre AF_PACKET ), sll_protocol et sll_ifindex .

L’opĂ©ration connect (2) n’est pas prise en charge sur les sockets packet.

Lorsque l’attribut MSG_TRUNC est transmis Ă  recvmsg (2), recv (2) ou recvfrom (2), la vĂ©ritable longueur du paquet sur le rĂ©seau est toujours renvoyĂ©e, mĂȘme si elle est plus grande que le tampon.

Types d’adresses

La structure sockaddr_ll est une adresse de couche physique indépendante du périphérique.

struct sockaddr_ll {
unsigned short sll_family; /* Toujours AF_PACKET */
unsigned short sll_protocol; /* Protocole couche physique */
int sll_ifindex; /* NumĂ©ro d’interface */
unsigned short sll_hatype; /* Type de matériel ARP */
unsigned char sll_pkttype; /* Type de paquet */
unsigned char sll_halen; /* Longueur de l’adresse */
unsigned char sll_addr[8]; /* Adresse couche physique */
};

Les membres de cette structure sont les suivants :
sll_protocol

est le type normalisĂ© du protocole Ethernet dans l’ordre des octets du rĂ©seau tel que dĂ©fini dans le fichier d’en-tĂȘte <linux/if_ether.h> . C’est par dĂ©faut le protocole du socket.

sll_ifindex

est le numĂ©ro d’interface (consultez netdevice (7)). 0 correspond Ă  n’importe quelle interface (autorisĂ©e uniquement pour la liaison). sll_hatype est un type ARP tel que dĂ©fini dans le fichier d’en-tĂȘte <linux/if_arp.h> .

sll_pkttype

contient le type de paquet. Les types valables sont PACKET_HOST pour un paquet destinĂ© Ă  l’hĂŽte local, PACKET_BROADCAST pour un paquet broadcast de couche physique, PACKET_MULTICAST pour un paquet envoyĂ© Ă  une adresse multicast de couche physique, PACKET_OTHERHOST pour un paquet destinĂ© Ă  un autre hĂŽte capturĂ© par un pilote de pĂ©riphĂ©rique en mode promiscuous et PACKET_OUTGOING pour un paquet provenant de l’hĂŽte local rebouclĂ© sur un socket packet. Cela n’a de signification qu’en rĂ©ception.

sll_addr
sll_halen

contiennent l’adresse de couche physique (par exemple IEEE 802.3) et sa longueur. L’interprĂ©tation exacte dĂ©pend du pĂ©riphĂ©rique.

Lorsque des paquets sont envoyĂ©s, il suffit d’indiquer sll_family , sll_addr , sll_halen , sll_ifindex et sll_protocol . Les autres champs devraient ĂȘtre Ă  zĂ©ro. sll_hatype et sll_pkttype sont remplis en rĂ©ception pour information.

Options de socket

Les options du socket packet sont configurées en appelant setsockopt (2) avec le niveau SOL_PACKET .
PACKET_ADD_MEMBERSHIP
PACKET_DROP_MEMBERSHIP

Les options des sockets packet permettent de configurer le multicasting de couche physique et le mode promiscuous. PACKET_ADD_MEMBERSHIP ajoute une liaison et PACKET_DROP_MEMBERSHIP la supprime. Les deux options attendent une structure packet_mreq en paramÚtre :

struct packet_mreq {
int mr_ifindex; /* NumĂ©ro d’interface */
unsigned short mr_type; /* Action */
unsigned short mr_alen; /* Longueur d’adresse */
unsigned char mr_address[8]; /* Adresse couche physique */
};

mr_ifindex contient le numĂ©ro de l’interface dont l’état doit ĂȘtre modifiĂ©. Le champ mr_type indique l’action Ă  effectuer. PACKET_MR_PROMISC valide la rĂ©ception de tous les paquets circulant sur le segment de rĂ©seau commun (souvent appelĂ© « mode promiscuous »), PACKET_MR_MULTICAST attache le socket au groupe multicast de couche physique indiquĂ© dans mr_address et mr_alen , et PACKET_MR_ALLMULTI demande au socket de recevoir tous les paquets multicast arrivant sur l’interface.

De plus, les ioctls classiques SIOCSIFFLAGS , SIOCADDMULTI et SIOCDELMULTI peuvent parvenir au mĂȘme rĂ©sultat.

PACKET_AUXDATA (depuis Linux 2.6.21)

Si cette option est activĂ©e, le socket packet fournit avec chaque paquet une structure de mĂ©tadonnĂ©es Ă  l’aide du champ de contrĂŽle de recvmsg (2). La structure peut ĂȘtre lue avec cmsg (3). Elle est dĂ©finie ci-dessous :

struct tpacket_auxdata {
__u32 tp_status;
__u32 tp_len; /* Longueur du paquet */
__u32 tp_snaplen; /* Longueur capturée */
__u16 tp_mac;
__u16 tp_net;
__u16 tp_vlan_tci;
__u16 tp_vlan_tpid; /* Depuis Linux 3.14 ; précédemment
c’était des octets de remplissage
non utilisés */
};

PACKET_FANOUT (depuis Linux 3.1)

Pour s’adapter au nombre de traitements des threads, les sockets packet peuvent former un groupe de dĂ©ploiement. Dans ce mode, tous les paquets correspondants sont mis en attente dans un seul socket du groupe. Un socket rejoint un groupe de dĂ©ploiement en appelant setsockopt (2) avec le niveau SOL_PACKET et l’option PACKET_FANOUT . Tous les espaces de noms rĂ©seau peuvent avoir jusqu’à 65536 groupes indĂ©pendants. Un socket sĂ©lectionne un groupe en encodant l’identifiant dans les 16 premiers bits de la valeur d’entier de cette option. Le premier socket packet Ă  rejoindre un groupe le crĂ©e implicitement. Pour rĂ©ussir Ă  rejoindre un groupe existant, les sockets packet suivants doivent avoir le mĂȘme protocole, la mĂȘme configuration de pĂ©riphĂ©rique, le mĂȘme mode de dĂ©ploiement et les mĂȘmes attributs (voir ci-dessous). Les sockets packet ne peuvent quitter un groupe de dĂ©ploiement qu’en fermant le socket. Le groupe est supprimĂ© quand le dernier socket est fermĂ©.

Le déploiement gÚre plusieurs algorithmes pour répartir le trafic entre les sockets comme suit :

-

Le mode par dĂ©faut, PACKET_FANOUT_HASH , envoie les paquets du mĂȘme flux au mĂȘme socket pour maintenir l’ordre par flux. Pour chaque paquet, il choisit un socket en prenant le hachage du flux de paquets modulo le nombre de sockets dans le groupe, oĂč le hachage du flux est un hachage sur les adresses de la couche rĂ©seau et les champs facultatifs de port de la couche transport.

-

Le mode rĂ©partition de charge PACKET_FANOUT_LB met en Ɠuvre un algorithme de tourniquet (round-robin).

-

PACKET_FANOUT_CPU sélectionne le socket en se basant sur le CPU sur lequel le paquet arrive.

-

PACKET_FANOUT_ROLLOVER traite toutes les données sur un seul socket, allant sur le suivant quand le socket devient débordé.

-

PACKET_FANOUT_RND sélectionne le socket en utilisant un générateur de nombres pseudo-aléatoires.

-

PACKET_FANOUT_QM (disponible depuis Linux 3.14) sélectionne le socket en utilisant le queue_mapping enregistré du tampon de socket (SKB) reçu.

Les modes de dĂ©ploiement acceptent des options supplĂ©mentaires. La fragmentation d’IP force les paquets du mĂȘme flux Ă  avoir des hachages de flux diffĂ©rents. L’attribut PACKET_FANOUT_FLAG_DEFRAG , si dĂ©fini, force la dĂ©fragmentation de paquets avant l’application du dĂ©ploiement, pour conserver l’ordre mĂȘme dans ce cas. Le mode de dĂ©ploiement et les options sont communiquĂ©s sur les deuxiĂšmes 16 bits de la valeur d’entier de cette option. L’attribut PACKET_FANOUT_FLAG_ROLLOVER active le mĂ©canisme de dĂ©placement comme une stratĂ©gie de sauvegarde : si l’algorithme de dĂ©ploiement originel sĂ©lectionne un socket dĂ©bordĂ©, le paquet se dĂ©place vers le suivant disponible.

PACKET_LOSS (avec PACKET_TX_RING )

Lorsqu’un paquet malformĂ© est trouvĂ© dans le tampon circulaire de transmission, le comportement par dĂ©faut est de rĂ©initialiser son tp_status Ă  TP_STATUS_WRONG_FORMAT et d’abandonner immĂ©diatement la transmission. Le paquet malformĂ© ainsi que les paquets suivants mis en file d’attente voient leur transmission bloquĂ©e. L’erreur de format doit ĂȘtre corrigĂ©e, la valeur tp_status associĂ©e doit ĂȘtre rĂ©initialisĂ©e Ă  TP_STATUS_SEND_REQUEST et le processus de transmission redĂ©marrĂ© par l’intermĂ©diaire de l’interface send (2). Cependant, si PACKET_LOSS est dĂ©fini, tout paquet malformĂ© est ignorĂ©, son tp_status est rĂ©initialisĂ© Ă  TP_STATUS_AVAILABLE et le processus de transmission continue.

PACKET_RESERVE (avec PACKET_RX_RING )

Par dĂ©faut, un tampon circulaire de rĂ©ception des paquets Ă©crit les paquets juste aprĂšs la structure de mĂ©tadonnĂ©es et le remplissage d’alignement. La valeur d’entier de cette option rĂ©serve une possibilitĂ© de transmission supplĂ©mentaire.

PACKET_RX_RING

CrĂ©er un tampon circulaire projetĂ© en mĂ©moire pour la rĂ©ception asynchrone de paquets. Le socket packet rĂ©serve une zone contiguĂ« d’espace d’adresse d’application, la dispose dans un tableau d’emplacements de paquet et copie les paquets (jusqu’à tp_snaplen ) dans les emplacements suivants. Tous les paquets sont prĂ©cĂ©dĂ©s d’une structure de mĂ©tadonnĂ©es similaire Ă  tpacket_auxdata . Les champs de protocole encodent la position des donnĂ©es dĂšs le dĂ©but de l’en-tĂȘte de mĂ©tadonnĂ©es. tp_net stocke la position de la couche rĂ©seau. Si le socket packet est de type SOCK_DGRAM , alors tp_mac est la mĂȘme. S’il est de type SOCK_RAW , alors ce champ stocke la position de la trame de couche liaison. Le socket packet et l’application communiquent le dĂ©but et la fin du tampon circulaire Ă  l’aide du champ tp_status . Tous les emplacements avec tp_status valant TP_STATUS_KERNEL appartiennent au socket packet. AprĂšs avoir rempli un emplacement, il modifie l’état de l’emplacement pour qu’il appartienne Ă  l’application. Lors d’une opĂ©ration normale, la nouvelle valeur de tp_status a au moins son bit TP_STATUS_USER activĂ©, pour signaler qu’un paquet reçu a Ă©tĂ© stockĂ©. Lorsque l’application a terminĂ© de traiter un paquet, elle transfĂšre la propriĂ©tĂ© de l’emplacement au socket en redĂ©finissant tp_status Ă  TP_STATUS_KERNEL .

Les sockets packet mettent en Ɠuvre plusieurs variantes du tampon circulaire de paquets. Des prĂ©cisions sur cette mise en place sont disponibles dans Documentation/networking/packet_mmap.rst dans l’arborescence des sources du noyau Linux.

PACKET_STATISTICS

RĂ©cupĂ©rer les statistiques du socket packet sous la forme d’une structure

struct tpacket_stats {
unsigned int tp_packets; /* Décompte total des paquets */
unsigned int tp_drops; /* Décompte des paquets jetés */
};

Recevoir les statistiques réinitialise les compteurs internes. La structure de statistiques est différente lorsque le tampon circulaire utilisé est de type TPACKET_V3 .

PACKET_TIMESTAMP (avec PACKET_RX_RING ; depuis Linux 2.6.36)

Le tampon circulaire de rĂ©ception des paquets stocke un horodatage dans l’en-tĂȘte de mĂ©tadonnĂ©es. Par dĂ©faut, c’est un horodatage logiciel gĂ©nĂ©rĂ© quand le paquet est copiĂ© dans le tampon circulaire. Cette option d’entier sĂ©lectionne le type d’horodatage. En plus du fonctionnement par dĂ©faut, il gĂšre deux formats matĂ©riels dĂ©crits dans Documentation/networking/timestamping.rst dans l’arborescence des sources du noyau Linux.

PACKET_TX_RING (depuis Linux 2.6.31)

CrĂ©er un tampon circulaire projetĂ© en mĂ©moire pour la transmission de paquets. Cette option est similaire Ă  PACKET_RX_RING et accepte les mĂȘmes arguments. L’application Ă©crit des paquets dans des emplacements avec tp_status Ă©gal Ă  TP_STATUS_AVAILABLE et les programme pour transmission en modifiant tp_status Ă  la valeur TP_STATUS_SEND_REQUEST . Quand les paquets sont prĂȘts Ă  ĂȘtre transmis, l’application appelle send (2) ou une de ses variantes. Les champs buf et len de cet appel sont ignorĂ©s. Si une adresse est passĂ©e en utilisant sendto (2) ou sendmsg (2), alors cela Ă©crase le socket par dĂ©faut. En cas de transmission rĂ©ussie, le socket rĂ©initialise tp_status Ă  TP_STATUS_AVAILABLE . Il interrompt immĂ©diatement la transmission en cas d’erreur sauf si PACKET_LOSS est dĂ©finie.

PACKET_VERSION (avec PACKET_RX_RING ; depuis Linux 2.6.27)

Par dĂ©faut, PACKET_RX_RING crĂ©e un tampon circulaire de rĂ©ception des paquets de variante TPACKET_V1 . Pour crĂ©er une autre variante, configurer la variante voulue en dĂ©finissant l’option d’entier avant de crĂ©er le tampon circulaire.

PACKET_QDISC_BYPASS (depuis Linux 3.14)

Par dĂ©faut, les paquets envoyĂ©s par un socket packet passent par la couche qdisc du noyau, dĂ©diĂ©e au contrĂŽle de trafic, ce qui rĂ©pond bien Ă  la majoritĂ© des cas d’utilisation. Les Ă©quipements de gĂ©nĂ©ration de trafic qui utilisent des sockets packet pour inonder par force brute le rĂ©seau — par exemple pour tester des appareils en charge comme le fait pktgen — peuvent contourner cette couche de contrĂŽle en dĂ©finissant cette option à 1. Un effet secondaire est l’absence de mise en mĂ©moire tampon des paquets par la couche qdisc, ce qui peut provoquer des pertes de paquets lorsque les files de transmission du pĂ©riphĂ©rique rĂ©seau sont pleines. L’utilisation de cette option est Ă  vos risques et pĂ©rils.

Ioctls

SIOCGSTAMP peut servir à obtenir l’horodatage du dernier paquet reçu. Le paramùtre est une variable struct timeval .

De plus, les ioctls standards définis dans netdevice (7) et socket (7) sont valables sur les sockets packet.

Traitement des erreurs

Les sockets packet ne gĂšrent pas d’autres erreurs que celles se produisant durant la transmission des paquets au pilote de pĂ©riphĂ©rique. Elles ne traitent pas le concept de file d’erreurs.

ERREURS

EADDRNOTAVAIL

Adresse de groupe multicast inconnue.

EFAULT

Adresse mémoire incorrecte.

EINVAL

Argument incorrect.

EMSGSIZE

Le paquet est plus grand que le MTU de l’interface.

ENETDOWN

L’interface n’est pas active.

ENOBUFS

Pas assez de mémoire pour le paquet.

ENODEV

Le nom du pĂ©riphĂ©rique ou le numĂ©ro d’interface indiquĂ© dans l’adresse de l’interface est inconnu.

ENOENT

Pas de paquet reçu.

ENOTCONN

Aucune adresse d’interface n’a Ă©tĂ© passĂ©e.

ENXIO

NumĂ©ro d’interface non valable dans son adresse.

EPERM

L’utilisateur n’a pas les privilĂšges nĂ©cessaires pour l’opĂ©ration.

De plus, d’autres erreurs peuvent ĂȘtre engendrĂ©es par le pilote bas niveau.

VERSIONS

AF_PACKET est une nouveauté de Linux 2.2. Les versions précédentes de Linux ne prenaient en charge que SOCK_PACKET .

NOTES

Pour la portabilitĂ©, il est conseillĂ© d’utiliser les fonctionnalitĂ©s AF_PACKET par l’intermĂ©diaire de l’interface pcap (3), bien que cela ne couvre qu’un sous-ensemble des possibilitĂ©s de AF_PACKET .

Les sockets packet SOCK_DGRAM n’essayent pas de crĂ©er ou de traiter les en-tĂȘtes IEEE 802.2 LLC pour une trame IEEE 802.3. Lorsque le protocole ETH_P_802_3 est indiquĂ© en Ă©mission, le noyau crĂ©e la trame 802.3 et remplit le champ de longueur. L’utilisateur doit fournir l’en-tĂȘte LLC pour obtenir un paquet entiĂšrement conforme. Les paquets 802.3 entrants ne sont pas multiplexĂ©s sur les champs du protocole DSAP/SSAP. À la place, ils sont fournis Ă  l’utilisateur sous le protocole ETH_P_802_2 avec un en-tĂȘte LLC ajoutĂ©. La liaison ETH_P_802_3 n’est donc pas possible, la liaison ETH_P_802_2 doit ĂȘtre utilisĂ©e Ă  la place, et vous devez rĂ©aliser le multiplexage de protocoles vous-mĂȘme. Le comportement par dĂ©faut en Ă©mission est l’encapsulation Ethernet DIX standard, avec le protocole renseignĂ©.

Les sockets packet ne sont pas soumis aux chaßnes de pare-feu en entrée ou sortie.

Compatibilité

Avec Linux 2.0, la seule façon d’obtenir un socket paquet Ă©tait avec l’appel :

socket(AF_INET, SOCK_PACKET, protocole)

C’est encore pris en charge mais obsolĂšte et fortement dĂ©conseillĂ©. La principale diffĂ©rence entre les deux mĂ©thodes est que SOCK_PACKET utilise l’ancienne struct sockaddr_pkt pour indiquer l’interface, ce qui ne fournit aucune indĂ©pendance vis-Ă -vis de la couche physique.

struct sockaddr_pkt {
unsigned short spkt_family;
unsigned char spkt_device[14];
unsigned short spkt_protocol;
};

spkt_family contient le type de périphérique, spkt_protocol est le type de protocole IEEE 802.3 comme défini dans <sys/if_ether.h> et spkt_device est le nom du périphérique sous forme de chaßne terminée par un octet NULL, par exemple eth0.

Cette structure est obsolĂšte et ne doit pas ĂȘtre employĂ©e dans des nouveaux programmes.

BOGUES

Gestion des en-tĂȘtes LLC

La gestion des en-tĂȘtes LLC IEEE 802.2/802.3 devrait ĂȘtre considĂ©rĂ©e comme un bogue.

ProblĂšmes avec MSG_TRUNC

L’extension MSG_TRUNC de recvmsg (2) est une bidouille horrible et devrait ĂȘtre remplacĂ©e par un message de contrĂŽle. Il n’y a actuellement aucun moyen d’obtenir l’adresse de destination originelle des paquets Ă  l’aide de SOCK_DGRAM .

spkt_device device name truncation

The spkt_device field of sockaddr_pkt has a size of 14 bytes, which is less than the constant IFNAMSIZ defined in <net/if.h> which is 16 bytes and describes the system limit for a network interface name. This means the names of network devices longer than 14 bytes will be truncated to fit into spkt_device . All these lengths include the terminating null byte ('\0')).

Issues from this with old code typically show up with very long interface names used by the Predictable Network Interface Names feature enabled by default in many modern Linux distributions.

The preferred solution is to rewrite code to avoid SOCK_PACKET . Possible user solutions are to disable Predictable Network Interface Names or to rename the interface to a name of at most 13 bytes, for example using the ip (8) tool.

ProblĂšmes de documentation

Les filtres des sockets ne sont pas documentés.

VOIR AUSSI

socket (2), pcap (3), capabilities (7), ip (7), raw (7), socket (7), ip (8),

RFC 894 pour l’encapsulation IP Ethernet standard. RFC 1700 pour l’encapsulation IP IEEE 802.3.

Le fichier d’en-tĂȘte <linux/if_ether.h> pour les protocoles de couche physique.

L’arbre des sources du noyau Linux. /Documentation/networking/filter.rst dĂ©crit comment appliquer des filtres Berkeley de paquets aux sockets packet. /tools/testing/selftests/net/psock_tpacket.c contient un exemple de code source pour toutes les versions de PACKET_RX_RING et PACKET_TX_RING .

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> et Jean-Paul Guillonneau <guillonneau.jeanpaul@free.fr>

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 .