alloc_hugepages

Autres langues

Langue: fr

Version: 31 mai 2007 (mandriva - 01/05/08)

Section: 2 (Appels système)

NOM

alloc_hugepages, free_hugepages - Allouer ou libérer des pages immenses

SYNOPSIS

 void *alloc_hugepages(int cle, void *adr, size_t lg,
 int prot ,int attr );
 
 int free_hugepages(void *adr);
 

DESCRIPTION

Les appels système alloc_hugepages() et free_hugepages(2) ont été introduits dans Linux 2.5.36 et retirés à nouveau dans le 2.5.54. Ils n'existent que sur i386 et ia64 (compilation avec l'option CONFIG_HUGETLB_PAGE). Dans Linux 2.4.20 le numéro d'appel système existe, mais échoue avec l'erreur ENOSYS.

Sur un i386, le mécanisme matériel de gestion mémoire manipule des pages ordinaires (4 KiB) et des pages immenses (2 à 4 MiB). De même, l'ia64 connaît des pages immenses de diverses tailles. Ces appels système servent à projeter ces pages immenses dans l'espace mémoire du processus ou à les libérer. Les pages immenses sont verrouillées en mémoire et jamais swappées.

Le paramètre cle est un identificateur. Lorsqu'il vaut zéro, les pages sont privées et non héritées par les processus descendants. Lorsqu'il est positif, les pages sont partagées avec les autres applications utilisant la même cle, et héritées par les processus enfants.

Le paramètre adr de free_hugepages(2) indique quelle page doit être libérée - il a été renvoyé lors de l'appel alloc_hugepages(). (La mémoire n'est véritablement libérée que lorsque tous ses utilisateurs la relâchent). Le paramètre adr de alloc_hugepages() est un désir que le noyau peut suivre ou non. Les adresses doivent être correctement alignées.

Le paramètre lg est la taille du segment désiré. Il doit s'agir d'un multiple de la taille d'une page immense.

Le paramètre prot indique le type de protection du segment. Il s'agit d'une association de PROT_READ, PROT_WRITE, PROT_EXEC.

Le paramètre flag est ignoré, sauf si cle est positive. Dans ce cas, si flag vaut IPC_CREAT, alors un nouveau segment de page énorme est créé si aucun n'existe avec cette clé. Sinon, l'erreur ENOENT est renvoyée si aucun segment correspondant à la clé n'existe. .SHVALEURRENVOYÉE S'il réussit alloc_hugepages() renvoie l'adresse du segment alloué, et free_hugepages(2) renvoie zéro. En cas d'erreur, ils renvoient -1 et remplissent errno avec le code d'erreur.

ERREURS

ENOSYS
L'appel système n'est pas supporté par ce noyau.

FICHIERS

/proc/sys/vm/nr_hugepages Nombre de pages énormes configurées. Peut être lu ou écrit.

/proc/meminfo Indique le nombre de pages énormes configurées, et leurs tailles dans les trois variables HugePages_Total, HugePages_Free, Hugepagesize.

CONFORMITÉ

Ces appels sont spécifiques à Linux sur processeurs Intel, et ne doivent pas être employés sur des programmes conçus pour être portables.

NOTES

Ces appels système ont disparu ; ils n'ont existé que dans les noyaux Linux 2.5.36 - 2.5.54. Maintenant, le système de fichiers hugetblfs peut être employé à leur place. La mémoire correspondant aux pages énormes (si le processeur les supportent) peut être obtenue par un mmap(2) des fichiers de ce système de fichiers virtuel.

Le nombre maximal de pages énormes peut être indiqué en utilisant l'argument hugepages= au boot.

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 18 février 2003 et révisée le 28 novembre 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 alloc_hugepages ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.