Man page - packet(7)
Packages contains this manual
- shm_overview(7)
- nss(5)
- proc_mtrr(5)
- intro(7)
- tcp(7)
- iso_8859-9(7)
- armscii-8(7)
- proc_kpagecount(5)
- initrd(4)
- mouse(4)
- proc_stat(5)
- x25(7)
- proc_interrupts(5)
- fifo(7)
- repertoiremap(5)
- icmp(7)
- futex(7)
- feature_test_macros(7)
- lp(4)
- bpf-helpers(7)
- epoll(7)
- proc_sys_dev(5)
- namespaces(7)
- proc_sysrq-trigger(5)
- proc_bus(5)
- cp1251(7)
- proc_pid_maps(5)
- proc_sys_vm(5)
- proc_pid_projid_map(5)
- st(4)
- proc_pid(5)
- issue(5)
- pid_namespaces(7)
- unicode(7)
- inode(7)
- hosts.equiv(5)
- iso-8859-13(7)
- proc_fb(5)
- proc_modules(5)
- proc_pid_autogroup(5)
- keyrings(7)
- sysvipc(7)
- proc_kmsg(5)
- cgroups(7)
- latin6(7)
- proc_pid_uid_map(5)
- unix(7)
- proc_pid_io(5)
- pts(4)
- packet(7)
- ld-linux.so(8)
- tzselect(8)
- iconv(1)
- proc_pid_syscall(5)
- proc_pid_net(5)
- proc_pid_pagemap(5)
- tty(4)
- proc_profile(5)
- standards(7)
- proc_pid_mounts(5)
- filesystems(5)
- iso-8859-15(7)
- locale(5)
- iso_8859_3(7)
- xattr(7)
- iso-8859-2(7)
- proc_uptime(5)
- persistent-keyring(7)
- credentials(7)
- proc_pid_timers(5)
- utmpx(5)
- vcsa(4)
- proc_pid_exe(5)
- proc_net(5)
- proc_timer_stats(5)
- ip(7)
- proc_pid_fd(5)
- ptmx(4)
- user_namespaces(7)
- resolv.conf(5)
- url(7)
- iso_8859_5(7)
- iso_8859-8(7)
- urn(7)
- process-keyring(7)
- proc_pid_auxv(5)
- proc_ksyms(5)
- proc_ide(5)
- veth(4)
- ldd(1)
- proc_swaps(5)
- landlock(7)
- proc_vmstat(5)
- system_data_types(7)
- cp1252(7)
- lirc(4)
- proc_kpageflags(5)
- random(7)
- precedence(7)
- cpuset(7)
- proc_pid_ns(5)
- acct(5)
- latin4(7)
- proc_pid_cgroup(5)
- proc_cpuinfo(5)
- iso_8859-2(7)
- proc_keys(5)
- charsets(7)
- pldd(1)
- proc_pid_stat(5)
- rtnetlink(7)
- netlink(7)
- ram(4)
- mem(4)
- iso-8859-6(7)
- proc_key-users(5)
- iso_8859_15(7)
- fanotify(7)
- proc_sys_net(5)
- sysfs(5)
- math_error(7)
- latin1(7)
- proc_pid_root(5)
- nptl(7)
- proc_cgroups(5)
- proc_iomem(5)
- proc_pid_statm(5)
- sem_overview(7)
- hier(7)
- full(4)
- proc_pid_status(5)
- proc_pid_cwd(5)
- proc_pid_cpuset(5)
- proc_scsi(5)
- uri(7)
- proc_diskstats(5)
- iso_8859_6(7)
- latin2(7)
- latin5(7)
- man-pages(7)
- ld.so(8)
- uts_namespaces(7)
- proc_pid_mountstats(5)
- intro(3)
- proc_pid_seccomp(5)
- proc_pid_wchan(5)
- attributes(7)
- symlink(7)
- mount_namespaces(7)
- charmap(5)
- tis-620(7)
- iso-8859-10(7)
- getent(1)
- proc_buddyinfo(5)
- ttytype(5)
- rtc(4)
- proc_malloc(5)
- suffixes(7)
- sln(8)
- signal(7)
- proc_sys_abi(5)
- signal-safety(7)
- time_namespaces(7)
- proc_pid_comm(5)
- raw(7)
- gai.conf(5)
- proc_crypto(5)
- locale(1)
- iso-8859-3(7)
- motd(5)
- proc_meminfo(5)
- iso-8859-8(7)
- protocols(5)
- proc_pid_map_files(5)
- pthreads(7)
- null(4)
- proc(5)
- zdump(8)
- socket(7)
- proc_sys_kernel(5)
- ddp(7)
- memusagestat(1)
- hd(4)
- iso-8859-14(7)
- shells(5)
- pipe(7)
- glob(7)
- proc_self(5)
- network_namespaces(7)
- utmp(5)
- proc_kcore(5)
- nsswitch.conf(5)
- sd(4)
- iso-8859-5(7)
- iso_8859_16(7)
- man(7)
- iso_8859-6(7)
- dir_colors(5)
- mq_overview(7)
- vsock(7)
- ascii(7)
- thread-keyring(7)
- fs(5)
- proc_pid_attr(5)
- proc_sys_debug(5)
- proc_sys(5)
- proc_pid_cmdline(5)
- pty(7)
- services(5)
- cgroup_namespaces(7)
- securetty(5)
- netdevice(7)
- iso_8859_13(7)
- host.conf(5)
- proc_pid_setgroups(5)
- proc_slabinfo(5)
- sock_diag(7)
- iso_8859-14(7)
- iso-8859-11(7)
- iso_8859_11(7)
- operator(7)
- regex(7)
- wavelan(4)
- proc_sys_fs(5)
- nologin(5)
- proc_pci(5)
- koi8-r(7)
- erofs(5)
- intro(2)
- utf8(7)
- proc_kallsyms(5)
- proc_sysvipc(5)
- queue(7)
- proc_sys_sunrpc(5)
- intro(5)
- latin8(7)
- mtrace(1)
- ipc_namespaces(7)
- dsp56k(4)
- iso_8859_4(7)
- proc_pid_smaps(5)
- proc_cmdline(5)
- rpc(5)
- proc_tty(5)
- proc_version(5)
- smartpqi(4)
- proc_pid_timerslack_ns(5)
- aio(7)
- session-keyring(7)
- resolver(5)
- slabinfo(5)
- wtmp(5)
- iso_8859_9(7)
- proc_locks(5)
- mailaddr(7)
- proc_pid_oom_score(5)
- kmem(4)
- iconvconfig(8)
- iso_8859-7(7)
- glibc(7)
- hostname(7)
- proc_thread-self(5)
- ipv6(7)
- iso_8859_7(7)
- proc_kpagecgroup(5)
- core(5)
- time(7)
- units(7)
- proc_dma(5)
- loop(4)
- address_families(7)
- zero(4)
- intro(4)
- procfs(5)
- iso_8859-4(7)
- vdso(7)
- tmpfs(5)
- iso-8859-16(7)
- iso_8859_10(7)
- user-session-keyring(7)
- libc(7)
- proc_fs(5)
- koi8-u(7)
- latin3(7)
- proc_tid_children(5)
- proc_pid_limits(5)
- proc_pid_coredump_filter(5)
- iso_8859-15(7)
- arp(7)
- urandom(4)
- iso_8859-10(7)
- hpsa(4)
- proc_pid_environ(5)
- boot(7)
- ftm(7)
- ld-linux(8)
- proc_driver(5)
- loop-control(4)
- iso_8859-16(7)
- proc_filesystems(5)
- tzfile(5)
- sprof(1)
- proc_pid_task(5)
- proc_pid_oom_score_adj(5)
- proc_mounts(5)
- iso-8859-4(7)
- iso_8859-1(7)
- utf-8(7)
- iso_8859-13(7)
- intro(6)
- proc_timer_list(5)
- rtld-audit(7)
- iso_8859-3(7)
- group(5)
- sched(7)
- proc_pid_clear_refs(5)
- hosts(5)
- iso_8859-11(7)
- numa(7)
- iso_8859_2(7)
- locale(7)
- iso-8859-1(7)
- fuse(4)
- proc_tid(5)
- proc_execdomains(5)
- proc_pid_mountinfo(5)
- intro(8)
- iso_8859_8(7)
- proc_loadavg(5)
- proc_pid_oom_adj(5)
- re_format(7)
- iso_8859_14(7)
- zic(8)
- bootparam(7)
- inotify(7)
- posixoptions(7)
- proc_partitions(5)
- iso-8859-9(7)
- proc_pid_mem(5)
- networks(5)
- proc_sys_user(5)
- udp(7)
- proc_zoneinfo(5)
- latin10(7)
- proc_pid_fdinfo(5)
- proc_pid_stack(5)
- memusage(1)
- spufs(7)
- pkeys(7)
- path_resolution(7)
- proc_ioports(5)
- intro(1)
- ldconfig(8)
- msr(4)
- svipc(7)
- port(4)
- proc_pid_personality(5)
- cciss(4)
- latin9(7)
- capabilities(7)
- localedef(1)
- vcs(4)
- iso_8859-5(7)
- elf(5)
- proc_sys_proc(5)
- console_codes(4)
- random(4)
- iso-8859-7(7)
- termcap(5)
- cpuid(4)
- environ(7)
- string_copying(7)
- proc_pid_gid_map(5)
- queue(3)
- termio(7)
- user-keyring(7)
- complex(7)
- latin7(7)
- proc_config.gz(5)
- udplite(7)
- kernel_lockdown(7)
- proc_devices(5)
- proc_apm(5)
- iso_8859_1(7)
- proc_pid_numa_maps(5)
apt-get install manpages
Available languages:
en fr ja ru zh_TW zh_CNManual
packet
NOMSYNOPSIS
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 .