mkfifo(3) Library Functions Manual mkfifo(3) NOM mkfifo, mkfifoat - Creer un fichier special FIFO (un tube nomme) BIBLIOTHEQUE Bibliotheque C standard (libc, -lc) SYNOPSIS #include #include int mkfifo(const char *chemin, mode_t mode); #include /* Definition des constantes AT_* */ #include int mkfifoat(int dirfd, const char *chemin, mode_t mode) ; Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : mkfifoat() : Depuis la glibc 2.10 : _POSIX_C_SOURCE >= 200809L avant la glibc 2.10 : _ATFILE_SOURCE DESCRIPTION La fonction mkfifo() cree un fichier special FIFO (tube nomme) a l'emplacement chemin. mode indique les permissions d'acces. Ces permissions sont modifiees par la valeur d'umask du processus : les permissions d'acces effectivement adoptees sont (mode & ~umask). Un fichier special FIFO est semblable a un tube (pipe), sauf qu'il est cree differemment. Plutot qu'un canal de communication anonyme, un fichier FIFO est insere dans le systeme de fichiers en appelant mkfifo(). Une fois qu'un fichier FIFO est cree, n'importe quel processus peut l'ouvrir en lecture ou ecriture, comme tout fichier ordinaire. En fait, il faut ouvrir les deux extremites simultanement avant de pouvoir effectuer une operation d'ecriture ou de lecture. L'ouverture d'un FIFO en lecture est generalement bloquante, jusqu'a ce qu'un autre processus ouvre le meme FIFO en ecriture, et inversement. Consultez fifo(7) pour la gestion non bloquante d'une FIFO. mkfifoat() La fonction mkfifoat() opere exactement de la meme facon que la fonction mkfifo(), a une difference pres (decrite ci-dessous). Si le chemin fourni dans chemin est un chemin relatif, alors il est interprete relativement au repertoire indique par le descripteur de fichier dirfd (et non relativement au repertoire courant du processus appelant, comme c'est le cas lorsque que mkfifo() est appelee avec un chemin relatif). Si chemin est un chemin relatif et si dirfd est la valeur speciale AT_FDCWD, alors chemin est interprete relativement au repertoire de travail courant du processus appelant (comme pour mkfifo()). Si pathname est absolu, alors dirfd est ignore. Consultez openat(2) pour une explication sur la necessite de mkfifoat(). VALEUR RENVOYEE La valeur renvoyee par mkfifo() et par mkfifoat() lorsqu'elles reussissent est 0. Si elles echouent, ces fonctions renvoient -1 et errno est defini pour preciser l'erreur. ERREURS EACCES L'un des repertoires dans chemin ne permet pas la recherche (execution). EBADF (mkfifoat()) chemin est relatif mais dirfd est ni AT_FDCWD, ni un descripteur de ficher valable. EDQUOT Le quota de blocs de disque ou d'inoeuds de l'utilisateur sur le systeme de fichiers a ete atteint. EEXIST nom_chemin existe deja. Cela inclut le cas ou nom_chemin est un lien symbolique, pouvant pointer nulle part. ENAMETOOLONG Soit la longueur totale de chemin est superieure a PATH_MAX, soit un element de chemin a une longueur plus grande que NAME_MAX. Sur les systemes GNU il n'y a pas de limite absolue a la longueur du nom d'un fichier, mais certains autres systemes en ont une. ENOENT Un des repertoires du chemin d'acces nom_chemin n'existe pas ou est un lien symbolique pointant nulle part. ENOSPC Le repertoire, ou le systeme de fichiers, n'a pas assez de place pour un nouveau fichier. ENOTDIR Un element, utilise comme repertoire, du chemin d'acces nom_chemin n'est pas en fait un repertoire. ENOTDIR (mkfifoat()) chemin est un chemin relatif et dirfd est un descripteur d'un fichier et non d'un repertoire. EROFS chemin est sur un systeme de fichiers en lecture seule. ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |mkfifo(), mkfifoat() | Securite des threads | MT-Safe | +---------------------------------+--------------------------+---------+ VERSIONS Elle est implementee au moyen de mknodat(2) STANDARDS POSIX.1-2008. HISTORIQUE mkfifo() POSIX.1-2001. mkfifoat() : glibc 2.4. POSIX.1-2008. VOIR AUSSI mkfifo(1), close(2), open(2), read(2), stat(2), umask(2), write(2), fifo(7) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Cedric Boutillier , Frederic Hantrais et Jean-Pierre Giraud Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 mkfifo(3)