dwww Home | Manual pages | Find package

pipe(2)                       System Calls Manual                      pipe(2)

NOM
       pipe, pipe2 - Créer un tube

BIBLIOTHÈQUE
       Bibliothèque C standard (libc, -lc)

SYNOPSIS
       #include <unistd.h>

       int pipe(int pipefd[2]);

       #define _GNU_SOURCE             /* See feature_test_macros(7) */
       #include <fcntl.h>              /* Définition des constantes O_* */
       #include <unistd.h>

       int pipe2(int pipefd[2], int flags);

       /* Sur Alpha, IA-64, MIPS, SuperH et SPARC/SPARC64, pipe() a le prototype    suivant ; voir les NOTES */

       #include <unistd.h>

       struct fd_pair {
       long fd[2];
       };
       struct fd_pair pipe(void);

DESCRIPTION
       pipe()  crée un tube, un canal unidirectionnel de données qui peut être
       utilisé pour la communication entre processus. Le  tableau  pipefd  est
       utilisé  pour  renvoyer  deux descripteurs de fichier faisant référence
       aux extrémités du tube. pipefd[0] fait référence à l'extrémité de  lec-
       ture  du  tube.  pipefd[1]  fait  référence à l'extrémité d'écriture du
       tube. Les données écrites sur l'extrémité d'écriture du tube sont mises
       en  mémoire  tampon  par  le  noyau jusqu'à ce qu'elles soient lues sur
       l'extrémité de  lecture  du  tube.  Pour  plus  de  détails,  consultez
       pipe(7).

       Si  flags est 0, alors pipe2() est identique à pipe(). Les valeurs sui-
       vantes peuvent être incluses à l'aide d'un OU binaire dans  flags  pour
       obtenir différents comportements :

       O_CLOEXEC
              Placer  l'attribut  « close-on-exec »  (FD_CLOEXEC) sur les deux
              nouveaux descripteurs de fichiers. Consultez la  description  de
              cet  attribut  dans  open(2) pour savoir pourquoi cela peut être
              utile.

       O_DIRECT (depuis Linux 3.4)
              Créer un tube qui assure les E/S en mode « packet ». Chaque opé-
              ration  write(2)  vers  le tube est exécutée avec un paquet dis-
              tinct et les opérations read(2) depuis le tube  lisent  un  seul
              paquet à la fois. Notez les précisions suivantes :

              •  Les opérations d'écriture dont la taille dépasse PIPE_BUF oc-
                 tets (voir pipe(7)) seront fractionnées en plusieurs paquets.
                 La constante PIPE_BUF est définie dans <limits.h>.

              •  Si  une  opération read(2) indique une taille du tampon infé-
                 rieure à celle du paquet à venir, alors seul le nombre  d'oc-
                 tets  demandé sera lu et les octets supplémentaires du paquet
                 seront écartés. Si l'on souhaite s'assurer que même  les  pa-
                 quets  les  plus  longs  seront  lus, il suffit de définir la
                 taille du tampon à PIPE_BUF (voir le point précédent).

              •  Les paquets de longueur nulle ne sont pas acceptés (une  opé-
                 ration  read(2)  qui indique une taille de tampon de longueur
                 zéro est sans effet et renvoie 0).

              Les anciens noyaux qui n'acceptent pas  cet  attribut  renvoient
              une erreur EINVAL.

              Depuis Linux 4.5, il est possible de modifier le paramètre O_DI-
              RECT d'un descripteur de fichier de tube en utilisant fcntl(2).

       O_NONBLOCK
              Placer l'attribut d'état de fichier O_NONBLOCK sur les  descrip-
              tions  de  fichier ouvert auxquelles renvoient les nouveaux des-
              cripteurs de fichiers. Utiliser cet attribut économise  des  ap-
              pels supplémentaires à fcntl(2) pour obtenir le même résultat.

       O_NOTIFICATION_PIPE
              Depuis  Linux 5.8,  le  mécanisme  de  notification générale est
              construit sur le tube où le noyau copie les messages de  notifi-
              cation  dans les tubes ouverts par l'espace utilisateur. Le pro-
              priétaire du tube doit dire au noyau  quelles  sources  d'événe-
              ments  à  surveiller et des filtres peuvent aussi être appliqués
              pour sélectionner quels sous-événements doivent être placés dans
              le tube.

VALEUR RENVOYÉE
       S'il  réussit, cet appel système renvoie 0. S'il échoue, il renvoie -1,
       errno est défini pour indiquer l'erreur et pipefd est laissé inchangé.

       Sur Linux (et d'autres systèmes), pipe() ne modifie pas pipefd  en  cas
       d'échec.  Une  exigence  qui  standardise ce comportement a été ajoutée
       dans POSIX.1-2008 TC2. L'appel système pipe2() spécifique  à  Linux  ne
       modifie donc pas pipefd en cas d'échec.

ERREURS
       EFAULT pipefd n'est pas valable.

       EINVAL (pipe2()) Valeur incorrecte dans flags.

       EMFILE La  limite du nombre de descripteurs de fichiers par processus a
              été atteinte.

       ENFILE La limite du nombre total de fichiers ouverts  pour  le  système
              entier a été atteinte.

       ENFILE La  limite  dure  de l'utilisateur en mémoire qu'il est possible
              d'allouer aux tubes a été atteinte et l'appelant n'est pas  pri-
              vilégié ; voir pipe(7).

       ENOPKG (pipe2())   O_NOTIFICATION_PIPE  a  été  passé  dans flags et la
              prise en  charge  pour  les  notifications  (CONFIG_WATCH_QUEUE)
              n'est pas compilée dans le noyau.

VERSIONS
       pipe2() a été ajouté dans Linux 2.6.27 ; la prise en charge de la glibc
       est disponible depuis la glibc 2.9.

STANDARDS
       pipe() : POSIX.1-2001, POSIX.1-2008.

       pipe2() est spécifique à Linux.

NOTES
       L'ABI SystemV sur certaines architectures permet d'utiliser  plus  d'un
       registre  pour renvoyer plusieurs valeurs ; diverses architectures (Al-
       pha, IA-64, MIPS, SuperH et SPARC/SPARC64) abusent  de  cette  fonction
       pour  implémenter  l'appel  système  pipe() de manière opérationnelle :
       l'appel ne prend aucun paramètre et renvoie une paire  de  descripteurs
       de fichier comme code de retour en cas de succès. La fonction enveloppe
       pipe() de la glibc gère cela de manière transparente.  Voir  syscall(2)
       pour  des  informations  sur  les  registres  utilisés  pour stocker le
       deuxième descripteur de fichier.

EXEMPLES
       Le programme suivant crée un tube, puis invoque fork(2) pour  créer  un
       processus  enfant ;  l'enfant hérite d'un double du jeu de descripteurs
       de fichier qui se rapportent au même tube.  Après  le  fork(2),  chaque
       processus  ferme  les  descripteurs dont il n'a pas besoin pour le tube
       (consultez pipe(7)). Le parent écrit  alors  la  chaîne  contenue  dans
       l'argument  de ligne de commande du programme dans le tube, et l'enfant
       lit cette chaîne un octet à la fois dans le tube, et l'affiche  sur  la
       sortie standard.

   Source du programme
       #include <stdio.h>
       #include <stdlib.h>
       #include <string.h>
       #include <sys/wait.h>
       #include <unistd.h>

       int
       main(int argc, char *argv[])
       {
           int    pipefd[2];
           char   buf;
           pid_t  cpid;

           if (argc != 2) {
               fprintf(stderr, "Utilisation : %s <chaîne>\n", argv[0]);
               exit(EXIT_FAILURE);
           }

           if (pipe(pipefd) == -1) {
               perror("pipe");
               exit(EXIT_FAILURE);
           }

           cpid = fork();
           if (cpid == -1) {
               perror("fork");
               exit(EXIT_FAILURE);
           }

           if (cpid == 0) {    /* L'enfant lit dans le tube */
               close(pipefd[1]);          /* Fermeture du descripteur en écriture inutilisé */

               while (read(pipefd[0], &buf, 1) > 0)
                   write(STDOUT_FILENO, &buf, 1);

               write(STDOUT_FILENO, "\n", 1);
               close(pipefd[0]);
               _exit(EXIT_SUCCESS);

           } else {            /* Le parent écrit argv[1] dans le tube */
               close(pipefd[0]);          /* Fermeture du descripteur en lecture inutilisé*/
               write(pipefd[1], argv[1], strlen(argv[1]));
               close(pipefd[1]);          /* Le lecteur verra EOF */
               wait(NULL);                /* Attente de l'enfant */
               exit(EXIT_SUCCESS);
           }
       }

VOIR AUSSI
       fork(2),   read(2),  socketpair(2),  write(2),  popen(3),  vmsplice(2),
       write(2), popen(3), pipe(7)

TRADUCTION
       La traduction française de cette page de manuel a été créée par  Chris-
       tophe  Blaess  <https://www.blaess.fr/christophe/>, Stéphan Rafin <ste-
       phan.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.cou-
       lon@wanadoo.fr>,  Julien  Cristau <jcristau@debian.org>, Thomas Huriaux
       <thomas.huriaux@gmail.com>, Nicolas François  <nicolas.francois@centra-
       liens.net>,  Florentin  Duneau <fduneau@gmail.com>, Simon Paillard <si-
       mon.paillard@resel.enst-bretagne.fr>,   Denis   Barbier    <barbier@de-
       bian.org>,  David  Prévot <david@tilapin.org>, Frédéric Hantrais <fhan-
       trais@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
       ⟨https://www.gnu.org/licenses/gpl-3.0.html⟩ 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.03   5 février 2023                         pipe(2)

Generated by dwww version 1.15 on Sat Jun 29 00:40:03 CEST 2024.