OPENAT

Section : Manuel du programmeur Linux (2)
Mise à jour de la version anglaise : 6 mars 2006
Index Menu principal  

NOM

openat - Ouvrir un fichier relativement à un descripteur de fichier de répertoire  

SYNOPSIS

#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

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 le chemin fourni dans pathname est relatif, il est interprété par rapport au répertoire référencé par le descripteur de fichier dirfd (plutôt que par rapport 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 si dirfd est la valeur spéciale AT_FDCWD, pathname est interprété par rapport au répertoire de travail courant du processus appelant (comme avec open(2)).

Si pathname est absolu, dirfd est ignoré.  

VALEUR RENVOYÉE

S'il réussit, openat() renvoie un nouveau descripteur de fichier. S'il échoue, il renvoie -1 et renseigne errno en conséquence.  

ERREURS

Les erreurs qui apparaissent pour open(2) peuvent se produire pour openat(). Les erreurs supplémentaires suivantes peuvent également se produire 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

openat() a été ajouté au noyau Linux dans sa version 2.6.16.  

CONFORMITÉ

Cet appel système n'est pas standard mais est proposé pour une inclusion dans une prochaine révision de POSIX.1. Un appel système similaire existe sur Solaris.  

NOTES

openat() et les autres appels système similaires suffixés par « at » sont fournis pour deux raisons.

Premièrement, openat() permet à une application d'éviter les problèmes d'accès concurrents lors de l'utilisation de open(2) pour ouvrir des fichiers dans des répertoires autres que le répertoire de travail courant. Ces problèmes résultent du fait que l'un des composant du chemin fourni à open(2) peut être modifié parallèlement à l'appel à open(2). De tels problèmes peuvent être évités en ouvrant 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 d'un « répertoire de travail courant » par thread grâce à des descripteurs de fichier maintenus par l'application. (Cette fonctionnalité peut également être obtenue en jouant avec /proc/self/fd/dirfd, mais de façon moins efficace.)  

VOIR AUSSI

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

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 23 juin 2008.

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.

 

Index

NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
VERSIONS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Dernière mise à jour : 23 juin 2008