man mincore (Appels systèmes) - Savoir quelles pages se trouvent en mémoire physique.

NOM

mincore - Savoir quelles pages se trouvent en mémoire physique.

SYNOPSIS

#include <unistd.h>

#include <sys/mman.h> int mincore(void *start, size_t length, unsigned char *vec);

DESCRIPTION

La fonction mincore réclame un vecteur (une table) indiquant quelles pages d'un fichier se trouvent en mémoire physique et peuvent être lues sans accès disque. Le noyau fournira les données concernant les length octets à partir de l'adresse start. En retour, le noyau aura rempli la zone vec avec des octets dont le bit de poids faible indiquent si la page est en mémoire physique. (Les autres bits sont indéfinis, réservés pour une possible utilisation ultérieure.) Bien sûr, ce n'est qu'un instantané - les pages qui ne sont pas verrouillées en mémoire peuvent aller et venir à tout moment, et le contenu de vec peut être déjà périmé au retour de l'appel.

Pour que mincore réussisse, start doit être alignée sur une frontière de page. C'est la responsabilité de l'appelant d'arrondir l'adresse à la page la plus proche. Le paramètre length n'est pas nécessairement un multiple de la taille de page. Le vecteur vec doit être assez grand pour contenir (length+PAGE_SIZE-1)/PAGE_SIZE octets. On peut connaître la taille de page en invoquant getpagesize(2).

VALEUR RENVOYÉE

Si elle réussit, la fonction mincore renvoie zéro. En cas d'erreur, elle renvoie -1 et rempli errno avec la valeur d'erreur.

ERREURS

EAGAIN le noyau manque temporairement de ressources.

EINVAL
n'est pas aligné sur une frontière de page, ou n'est pas une valeur positive.
EFAULT
vec pointe vers une adresse illégale.
ENOMEM
la zone entre address et address + length contient de la mémoire autre qu'une projection de fichier.

BOGUES

Jusqu'à présent (Linux 2.6.5), mincore ne renvoie pas d'information correcte pour une projection MAP_PRIVATE.

CONFORMITÉ

mincore n'appartient ni à POSIX ni aux Spécifications Single Unix.

HISTORIQUE

La fonction mincore() est apparue dans 4.4BSD.

DISPONIBILITÉ

Depuis Linux 2.3.99pre1 et GlibC 2.2.

VOIR AUSSI

TRADUCTION

Christophe Blaess, 1996-2003.