man ether_aton (Fonctions bibliothèques) - Routines de manipulation d'adresses Ethernet.
NOM
ether_aton, ether_ntoa, ether_ntohost, ether_hosttonn, ether_line, ether_ntoa_r, ether_aton_r - Routines de manipulation d'adresses Ethernet.
SYNOPSIS
#include <netinet/ether.h> char * ether_ntoa(const struct ether_addr *addr); struct ether_addr * ether_aton(const char *asc); int ether_ntohost(char *hostname, const struct ether_addr *addr); int ether_hostton(const char *hostname, struct ether_addr *addr); int ether_line(const char *line, struct ether_addr *addr, char *hostname); /* extensions GNU */
char * ether_ntoa_r(const struct ether_addr *addr, char *buf); struct ether_addr * ether_aton_r(const char *asc, struct ether_addr *addr);
DESCRIPTION
ether_aton() convertit une adresse d'hôte Ethernet sur 48-bits asc de la notation standard hexadécimal et séparateurs deux-points en données binaire dans l'ordre des octets du réseau et renvoie un pointeur dans un buffer alloué de manière statique, que les appels ultérieurs écraseront. ether_aton renvoie NULL si l'adresse est invalide.
La fonction ether_ntoa() convertit l'adresse d'hôte Ethernet binaire addr dans l'ordre des octets du réseau en une chaîne dans la notation standard hexadécimal et deux-points, en omettant les zéros en tête. La chaîne est renvoyée dans un buffer alloué de manière statique, que les appels ultérieurs écraseront.
La fonction ether_ntohost() met en correspondance une adresse Ethernet en un nom d'hôte trouvé dans /etc/ethers et renvoie une valeur non-nulle si elle ne trouve pas.
La fonction ether_ntohost() met en correspondance un nom d'hôte et une adresse Ethernet dans /etc/ethers et renvoie une valeur non-nulle si elle ne trouve pas.
La fonction ether_line() examine une ligne dans le format de /etc/ethers (adresse Ethernet suivi de blancs et d'un nom d'hôte ; « # » introduit un commentaire) et renvoie une paire adresse / nom d'hôte, ou une valeur non-nulle si elle ne trouve pas. Le buffer pointé par hostname doit être assez grand, par exemple avoir la même longueur que la ligne line.
Les fonctions ether_ntoa_r et ether_aton_r sont les versions réentrantes et sûres en multi-threads de ether_ntoa et ether_aton respectivement, et n'utilisent pas de buffers statiques.
La structure ether_addr est définie dans net/ethernet.h ainsi :
struct ether_addr { u_int8_t ether_addr_octet[6]; }
BOGUES
L'implémentation de ether_line() dans la GlibC 2.2.5 est erronée.
CONFORMITÉ
BSD 4.3, SunOS
VOIR AUSSI
TRADUCTION
Christophe Blaess, 2003.