man fsync (Appels systèmes) - Synchroniser un fichier en mémoire avec le disque.

NOM

fsync - Synchroniser un fichier en mémoire avec le disque.

SYNOPSIS

#include <unistd.h> int fsync (int fd); int fdatasync (int fd);

DESCRIPTION

fsync copie sur le disque tous les morceaux encore en mémoire d'un fichier, et attend que le périphérique signale que toutes les portions sont stockées. Cet appel-système met également à jour les informations d'état du fichier. Il ne s'assure pas obligatoirement que les informations concernant le répertoire aient atteint le disque. Pour cela, un appel explicite de fsync sur le descripteur de fichier du répertoire est nécessaire.

VALEUR RENVOYÉE

Les appels-système renvoient 0 s'ils reussissent, ou -1 s'ils échouent, auquel cas errno contient le code d'erreur.

ERREURS

EBADF
fd n'est pas un descripteur de fichier valide ouvert en écriture.
EROFS , EINVAL
fd est associé à un type de fichier spécial qui ne permet pas de synchronisation.
EIO
Une erreur s'est produite pendant la synchronisation.

NOTES

fdatasync effectue la même chose que fsync mais il n'envoie sur le disque que les données de l'utilisateur, pas les informations d'état du fichier, ni les horodatages.

Si le disque dur dispose d'un tampon en écriture, les données ne sont peut être pas enregistrées définitivement lorsque fsync se termine.

Lorsqu'un système de fichiers ext2 est monté avec l'option sync, les entrées de répertoires sont également synchronisées lors de l'appel à fsync.

Sur les noyaux antérieurs au 2.4, fsync peut être sensiblement inefficace sur les gros fichiers. Une autre solution peut être l'utilisation de l'attribut O_SYNC lors de l'invocation de open(2).

COMPATIBILITÉ

POSIX.1b (précédement POSIX.4)

VOIR AUSSI

TRADUCTION

Christophe Blaess, 1996-2003.