posix_fadvise   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (2)
Updated: 14 février 2003
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
posix_fadvise - Prédéclarer des accès aux données d'un fichier  



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

int posix_fadvise(int fd, off_t offset, off_t len, int advice);
 



DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Les programmes peuvent utiliser posix_fadvise() pour annoncer leur intention d'accéder aux données d'un fichier suivant un certain ordre, permettant ainsi au noyau de réaliser les optimisations appropriées.

L'indication advice s'applique à une région (pas nécessairement existante) débutant à offset et s'étendant sur len octets (ou jusqu'à la fin du fichier si len vaut zéro) dans le fichier référencé par fd . L'indication n'oblige à rien, il s'agit seulement d'une supposition concernant le comportement futur de l'application.

Les valeurs possibles pour advice incluent :

POSIX_FADV_NORMAL
Indique que l'application n'a pas d'indice particulier concernant les accès aux données du fichier. Le noyau appliquera son comportement par défaut.
POSIX_FADV_SEQUENTIAL
L'application pense accéder aux données séquentiellement (dans l'ordre de offsets croissants).
POSIX_FADV_RANDOM
Les accès se feront de manière aléatoire.
POSIX_FADV_NOREUSE
Les données ne seront accédées qu'une seule fois.
POSIX_FADV_WILLNEED
Les données seront accédées dans le futur proche.
POSIX_FADV_DONTNEED
Les données ne seront pas accédées dans le futur proche.
 



VALEUR RENVOYÉE   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
L'appel renvoie zéro s'il réussit. S'il échoue, un numéro d'erreur est renvoyé.  



ERREURS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
EBADF
L'argument fd n'est pas un descripteur de fichier valide.
EINVAL
L'indication advice est invalide.
ESPIPE
Le descripteur correspond à un tube ou une FIFO. (Linux renvoie en fait EINVAL dans ce cas).
 



VERSIONS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
posix_fadvise() est apparu dans le noyau 2.5.60. La glibc le prend en charge depuis la version 2.2.  



CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
POSIX.1-2001. Veuillez noter que le type du paramètre len a été modifié de size_t en off_t dans la spécification POSIX.1-2003 TC1.  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Sous Linux, POSIX_FADV_NORMAL configure la fenêtre de lecture anticipée à sa taille par défaut pour le périphérique concerné. POSIX_FADV_SEQUENTIAL double cette taille, et POSIX_FADV_RANDOM désactive la lecture anticipée. Ces modifications affectent le fichier entier, pas seulement la région indiquée (mais les autres descripteurs ouverts sur le même fichier ne sont pas modifiés).

POSIX_FADV_WILLNEED initialise une lecture non bloquante de la région indiquée dans le cache. La quantité de données lues peut être diminuée suivant la charge de la mémoire virtuelle (quelques méga-octets seront en général disponibles et souvent suffisants).

Bans les noyaux précédents le 2.6.18, POSIX_FADV_NOREUSE avait la même sémantique que POSIX_FADV_WILLNEED. C'était probablement un bogue ; depuis le noyau 2.6.18, cet attribut est une instruction ineffective.

POSIX_FADV_DONTNEED essaye de libérer les pages de cache associées avec la région indiquée. Ceci est utile par exemple lors du parcours de très gros fichiers. Un programme peut ainsi demander régulièrement au noyau de libérer les pages déjà utilisées, pour éviter que des pages plus utiles ne soient éliminées à leur place.

Les pages qui n'ont pas encore été écrites ne sont pas affectées, ainsi si une application veut s'assurer que les pages seront relâchées, elle devrait appeler fsync(2) ou fdatasync(2) d'abord.  




BOGUES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Dans les noyaux précédent le 2.6.6, si len était spécifié à 0, cela était interprété littéralement comme « zéro octet » plutôt que comme « tous les octets jusqu'à la fin du fichier ».  



VOIR AUSSI   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
readahead(2), posix_fallocate(3), feature_test_macros(7) posix_madvise(3),  



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

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 18 juillet 2003 et révisée le 6 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 posix_fadvise ». 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
BOGUES
VOIR AUSSI
TRADUCTION

Table des mots clés   Début   Suivant   Sommaire   Préc.page.lue   Accueil
EBADFERREURS
EINVALERREURS
ESPIPEERREURS
POSIX_FADV_DONTNEEDDESCRIPTION
POSIX_FADV_NOREUSEDESCRIPTION
POSIX_FADV_NORMALDESCRIPTION
POSIX_FADV_RANDOMDESCRIPTION
POSIX_FADV_SEQUENTIALDESCRIPTION
POSIX_FADV_WILLNEEDDESCRIPTION



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

Valid HTML 4.01 Transitional