Les MANs Linux en français...
SEND
Section: Manuel du programmeur Linux (2)Updated: 4 Juin 2001
Index Retour au Menu Principal
NOM
send, sendto, sendmsg - Envoyer un message sur une socket.SYNOPSIS
#include <sys/types.h>#include <sys/socket.h>
int send(int s, const void *msg, size_t len, int flags);
int sendto(int s, const void *msg, size_t len, int flags, const struct sockaddr *to, socklen_t tolen);
int sendmsg(int s, const struct msghdr *msg, int flags);
DESCRIPTION
Send, sendto, et sendmsg permettent de transmettre un message à destination d'une autre socket. Send ne peut être utilisé qu'avec les sockets connectée alors que sendto et sendmsg peuvent être utilisés tout le temps.L'adresse de la cible est donnée par to avec la longueur tolen. la longueur du message est indiquée dans len. Si le message est trop long pour être transmis intégralement au protocole sous-jacent, l'erreur EMSGSIZE sera déclenchée et rien ne sera émis.
Aucune indication d'échec de distribution n'est fournie par send. Seules les erreurs locales sont détectées, et indiquées par une valeur de retour -1.
Si la socket ne dispose pas de la place suffisante pour le message, alors send va bloquer, à moins que la socket ait été configurée en mode d'entrées/sorties non-bloquantes auquel cas elle renverra EAGAIN. On peut utiliser l'appel système select(2) pour vérifier s'il est possible d'émettre des données.
Le paramètre flags peut contenir une ou plusieurs des options suivantes
- MSG_OOB
- est utilisée pour émettre des données hors-bande sur une socket qui l'autorise (par ex : SOCK_STREAM). Le protocole sous-jacent doit également autoriser l'émission de données hors-bande.
- MSG_DONTROUTE
- est utilisé pour empêcher la transmission d'un paquet vers une passerelle, n'envoyer de données que vers les hôtes directement connectés au réseau. Ceci n'est normalement employé que par les programmes de diagnostique ou de routage. Cette option n'est définie que pour les familles de protocoles employant le routage, pas les sockets par paquets.
- MSG_DONTWAIT
- active le mode non-bloquant. Une opération qui devrait bloquer renverra EAGAIN à la place (Cela peut être également paramétré avec l'option O_NONBLOCK de la fonction F_SETFL de fcntl(2)).
- MSG_NOSIGNAL
- demande de ne pas envoyer de signal SIGPIPE d'erreur sur les sockets connectées lorsque le correspondant coupe la connexion. L'erreur EPIPE est toutefois renvoyée.
- MSG_CONFIRM (Depuis Linux 2.3)
- Indiquer à la couche de liaison qu'une réponse correcte a été reçue du correspondant. Si la couche de liaison n'a pas cette confirmation, elle va ré-interroger régulièrement le voisinage (par exemple avec un ARP unicast). Seulement valide pour les sockets SOCK_DGRAM et SOCK_RAW et uniquement implémenté pour IPv4 et IPv6. Voir arp(7) pour plus de détails.
La définition de la structure msghdr se trouve ci-dessous. Voir recv(2) pour une description exacte de ses champs.
-
-
struct msghdr { void * msg_name; /* optional address */ socklen_t msg_namelen; /* size of address */ struct iovec * msg_iov; /* scatter/gather array */ size_t msg_iovlen; /* # elements in msg_iov */ void * msg_control; /* ancillary data, see below */ socklen_t msg_controllen; /* ancillary data buffer len */ int msg_flags; /* flags on received message */ };
-
On peut transmettre des informations de service en employant les membres msg_control et msg_controllen. La longueur maximale du buffer de service que le noyau peut gérer est limité par socket par la valeur net.core.optmem_max de sysctl(). Voir socket(7).
VALEUR RENVOYÉE
Ces appels systèmes renvoient le nombre de caractères émis, ou -1 s'ils échouent, auquel cas errno contient le code d'erreur.ERREURS
Voici les erreurs standards engendrés par la couche socket. Des erreurs supplémentaires peuvent être déclenchées par les protocoles sous-jacents. Voir leurs pages de manuel respectives.- EBADF
- Descripteur de socket invalide.
- ENOTSOCK
- L'argument s n'est pas une socket.
- EFAULT
- Un paramètre pointe en dehors de l'espace d'adressage accessible.
- EMSGSIZE
- La socket nécessite une émission intégrale du message mais la taille de celui-ci ne le permet pas.
- EAGAIN ou EWOULDBLOCK
- La socket est non-bloquante et l'opération demandée bloquerait.
- ENOBUFS
- La file d'émission de l'interface réseau est pleine. Ceci indique généralement une panne de l'interface réseau, mais peut également être dû à un engorgement passager. Ceci ne doit pas se produire sous Linux, les paquets sont silencieusement éliminés.
- EINTR
- Un signal a été reçu.
- ENOMEM
- Pas assez de mémoire pour le noyau.
- EINVAL
- Un argument invalide a été transmis.
- EPIPE
- L'écriture est impossible (correspondant absent). Dans ce cas le processus recevra également un signal SIGPIPE sauf s'il a activée l'option MSG_NOSIGNAL.
CONFORMITÉ
BSD 4.4 (cet appel système est apparu dans BSD 4.2), SVr4.MSG_CONFIRM est une extension Linux.
NOTE
Les prototypes fournis plus haut suivent les Spécification Single Unix, tout comme glibc2. L'argument flags était un `int' dans BSD 4.*, mais `unsigned int' dans libc4 et libc5. L'argument len était un `int' dans BSD 4.* et libc4, mais un `size_t' dans libc5; L'argument tolen était un `int' dans BSD 4.*, libc4 et libc5. Voir aussi les notes accompagnant la page accept(2).VOIR AUSSI
fcntl(2), recv(2), select(2), getsockopt(2), sendfile(2), socket(2), write(2), socket(7), ip(7), tcp(7), udp(7)TRADUCTION
Christophe Blaess, 1997.
Index
Time: 21:43:36 GMT, December 19, 2004