openat   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (2)
Updated: 6 mars 2006
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
openat - Ouvrir un fichier relativement à un descripteur de fichier de répertoire  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#define _ATFILE_SOURCE
#include <fcntl.h>

int openat(int dirfd, const char *pathname, int flags);
int openat(int dirfd, const char *pathname, int flags, mode_t mode);
 



DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
L'appel système openat() opère de la même manière que open(2), excepté pour les différences décrites dans cette page de manuel.

Si pathname est relatif, il est interprété relativement au répertoire référencé par le descripteur de fichier dirfd (plutôt que relativement au répertoire de travail courant du processus appelant, comme cela est fait par open(2) pour un chemin relatif).

Si pathname est relatif et que dirfd est la valeur spéciale AT_FDCWD, pathname est interprété relativement au répertoire de travail courant du processus appelant (comme avec open(2)).

Si pathname est absolu, dirfd est ignoré.  




VALEUR RENVOYÉE   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
S'il réussit, openat() renvoie un nouveau descripteur de fichier. S'il échoue, il renvoie -1 et écrit errno en conséquence.  



ERREURS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Les mêmes erreurs qui apparaissent pour open(2) peuvent apparaître pour openat(). Les erreurs supplémentaires suivantes peuvent également apparaître pour openat() :
EBADF
dirfd n'est pas un descripteur de fichier valide.
ENOTDIR
pathname est relatif et dirfd est un descripteur de fichier se référant à un fichier autre qu'un répertoire.
 



VERSIONS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
openat() a été ajouté à Linux dans le noyau 2.6.16.  



CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Cet appel système n'est pas standard mais est proposé pour une inclusion dans une future révision de POSIX.1. Il existe un appel système similaire sur Solaris.  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
openat() et les autres appels système similaires suffixés par « at » sont supportés pour deux raisons.

Premièrement, openat() permet à une application d'éviter les situations de concurrence qui pourraient survenir lors de l'utilisation de open(2) pour ouvrir des fichiers dans des répertoires autres que le répertoire de travail courant. Ces situations de concurrence résultent du fait qu'un composant du préfixe répertoire fourni à open(2) peut être modifié en parallèle de l'appel à open(2). De telles situations de concurrence peuvent être évitées par l'ouverture d'un descripteur de fichier pour le répertoire cible et en spécifiant ce descripteur de fichier comme argument dirfd à openat().

Deuxièmement, openat() permet l'implémentation de « répertoire de travail courant » par thread via un (des) descripteur(s) de fichier maintenu(s) par l'application. (Cette fonctionnalité peut également être obtenue par des bidouillages basés sur l'utilisation de /proc/self/fd/dirfd, en en moins efficace.) Il permet également d'éviter diverses sortes de conditions de concurrence qui pourraient survenir après la suppression de répertoire lors du parcours du système de fichiers par une application.  




VOIR AUSSI   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
faccessat(2), fchmodat(2), fchownat(2), fstatat(2), futimesat(2), linkat(2) mkdirat(2), mknodat(2), open(2), readlinkat(2), renameat(2), symlinkat(2), unlinkat(2), mkfifoat(3), path_resolution(7)  



TRADUCTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 25 juillet 2006 et révisée le 22 décembre 2007.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 openat ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.


 



Sommaire   Début   Suivant   Sommaire   Préc.page.lue   Accueil
NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
VERSIONS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Table des mots clés   Début   Suivant   Sommaire   Préc.page.lue   Accueil
EBADFERREURS
ENOTDIRERREURS



Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:49:19, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional