.\" -*- coding: UTF-8 -*- .\" Copyright (c) 1996 Tom Bjorkholm .\" .\" %%%LICENSE_START(GPLv2+_DOC_FULL) .\" This is free documentation; you can redistribute it and/or .\" modify it under the terms of the GNU General Public License as .\" published by the Free Software Foundation; either version 2 of .\" the License, or (at your option) any later version. .\" .\" The GNU General Public License's references to "object code" .\" and "executables" are to be interpreted as the output of any .\" document formatting or typesetting system, including .\" intermediate and printed output. .\" .\" This manual is distributed in the hope that it will be useful, .\" but WITHOUT ANY WARRANTY; without even the implied warranty of .\" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the .\" GNU General Public License for more details. .\" .\" You should have received a copy of the GNU General Public .\" License along with this manual; if not, see .\" . .\" %%%LICENSE_END .\" .\" 1996-04-11 Tom Bjorkholm .\" First version written (1.3.86) .\" 1996-04-12 Tom Bjorkholm .\" Update for Linux 1.3.87 and later .\" 2005-10-11 mtk: Added NOTES for MREMAP_FIXED; revised EINVAL text. .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH MREMAP 2 "6 mars 2019" Linux "Manuel du programmeur Linux" .SH NOM mremap \- Modifier une projection de la mémoire virtuelle .SH SYNOPSIS .nf \fB#define _GNU_SOURCE\fP /* Consultez feature_test_macros(7) */ \fB#include \fP .PP \fBvoid *mremap(void *\fP\fIold_address\fP\fB, size_t \fP\fIold_size\fP\fB,\fP \fB size_t \fP\fInew_size\fP\fB, int \fP\fIflags\fP\fB, ... /* void *\fP\fInew_address\fP\fB */);\fP .fi .SH DESCRIPTION \fBmremap\fP() agrandit (ou diminue) une projection (Ndt\ : mapping) de mémoire virtuelle en mémoire réelle, en la déplaçant éventuellement (sous contrôle de l'argument \fIflags\fP et de la place disponible dans l'espace d'adressage virtuel). .PP \fIold_address\fP est l'ancienne adresse du bloc de mémoire virtuelle à agrandir (ou à diminuer). Veuillez noter que \fIold_address\fP doit être alignée sur une frontière de page. \fIold_size\fP est l'ancienne taille du bloc de mémoire virtuelle. \fInew_size\fP est la taille désirée pour le nouveau bloc de mémoire. Un cinquième argument, \fInew_address\fP, peut éventuellement être fourni\ ; voyez la description de \fBMREMAP_FIXED\fP ci\-dessous. .PP Si la valeur de \fIold_size\fP est de zéro et si \fIold_address\fP renvoie à une projection partageable (voir \fBMAP_SHARED\fP de \fBmmap\fP(2)), \fBmremap\fP() créera une nouvelle projection des mêmes pages. \fInew_size\fP sera la taille de la nouvelle projection et l'emplacement de la nouvelle projection peut être indiqué avec \fInew_address\fP\ ; voir la description de \fBMREMAP_FIXED\fP ci\-dessous. Si une nouvelle projection est demandée à l'aide de cette méthode, l'attribut \fBMREMAP_MAYMOVE\fP doit être indiqué également. .PP Sous Linux, la mémoire est divisée en pages. Un processus utilisateur dispose d'un ou plusieurs segments linéaires de mémoire virtuelle. À chaque segment correspond une ou plusieurs projections dans les pages de mémoire réelle (dans la table des pages). Chaque segment de mémoire virtuelle dispose de ses propres droits d'accès (sa protection), ce qui peut déclencher des fautes de segmentation si la mémoire est utilisée incorrectement (par exemple, en écrivant dans un segment en lecture seule). De même, une tentative d'accès à la mémoire en dehors des segments déclenche une faute de segmentation. .PP \fBmremap\fP() utilise le schéma de la table des pages de Linux. \fBmremap\fP() modifie la correspondance entre les adresses virtuelles et les pages de mémoire réelle. Ce mécanisme peut être utilisé pour implémenter un \fBrealloc\fP(3) très efficace. .PP L'argument de masquage \fIflags\fP est \fB0\fP ou un des drapeaux suivants\ : .TP \fBMREMAP_MAYMOVE\fP Par défaut, s'il n'y a pas suffisamment d'espace pour agrandir une projection à son emplacement actuel, \fBmremap\fP() échoue. Si ce drapeau est utilisé, le noyau est autorisé à déplacer la projection à une autre adresse virtuelle si nécessaire. Si la projection est déplacée, les pointeurs absolus vers l'ancienne projection deviennent caduques (il faut utiliser des décalages par rapport à l'adresse de début de la projection). .TP \fBMREMAP_FIXED\fP (depuis Linux 2.3.31) Ce drapeau a un but similaire à \fBMAP_FIXED\fP pour \fBmmap\fP(2). S'il est utilisé, \fBmremap\fP() prend un cinquième argument \fIvoid\ *new_address\fP qui contient une adresse alignée sur un début de page vers laquelle la projection doit être déplacée. Toute projection existant précédemment dans la zone entre \fInew_address\fP et \fInew_size\fP est supprimée. Si \fBMREMAP_FIXED\fP est utilisé, \fBMREMAP_MAYMOVE\fP doit l'être aussi. .PP Si le segment de mémoire indiqué par \fIold_address\fP et \fIold_size\fP est verrouillé (par \fBmlock\fP(2) ou similaire), ce verrou est maintenu quand le segment est modifié et/ou déplacé. Par conséquent, la quantité de mémoire verrouillée par le processus peut changer. .SH "VALEUR RENVOYÉE" \fBmremap\fP() renvoie un pointeur sur la nouvelle zone de mémoire virtuelle s'il réussit. En cas d'échec, la valeur \fBMAP_FAILED\fP (c'est\-à\-dire \fI(void\ *)\ \-1\fP) est renvoyée et \fIerrno\fP contient le code d'erreur. .SH ERREURS .TP \fBEAGAIN\fP L'appelant a tenté d'agrandir un segment de mémoire verrouillé, mais c'est impossible sans dépasser la limite \fBRLIMIT_MEMLOCK\fP. .TP \fBEFAULT\fP Erreur de segmentation («\ Segmentation fault\ »). Une adresse dans l'intervalle entre \fIold_address\fP et \fIold_address\fP+\fIold_size\fP n'est pas une adresse virtuelle valable pour ce processus. On peut également obtenir \fBEFAULT\fP même s'il existe des projections recouvrant la zone complète demandée, mais que ces projections sont de types différents. .TP \fBEINVAL\fP Un paramètre non valable a été donné. Parmi les causes possibles\ : .RS .IP * 3 \fIold_address\fP n'était pas aligné sur une page\ ; .IP * une autre valeur que \fBMREMAP_MAYMOVE\fP ou \fBMREMAP_FIXED\fP était indiquée dans \fIflags\fP\ ; .IP * \fInew_size\fP était zéro\ ; .IP * \fInew_size\fP ou \fInew_address\fP n'était pas valable\ ; .IP * la nouvelle plage d'adresses indiquée par \fInew_address\fP et \fInew_size\fP chevauche l'ancienne plage d'adresses indiquée par \fIold_address\fP et \fIold_size\fP\ ; .IP * \fBMREMAP_FIXED\fP était indiqué sans \fBMREMAP_MAYMOVE\fP\ ; .IP * \fIold_size\fP était de zéro et \fIold_address\fP ne renvoie pas à une projection partageable (mais voir BOGUES)\ ; .IP * \fIold_size\fP valait zéro et l'attribut \fBMREMAP_MAYMOVE\fP n'était pas indiqué. .RE .TP \fBENOMEM\fP La zone de mémoire ne peut pas être agrandie à l'emplacement virtuel actuel, et l'option \fBMREMAP_MAYMOVE\fP n'a pas été fournie dans \fIflags\fP. Ou encore, il n'y a plus assez de mémoire (virtuelle) disponible. .SH CONFORMITÉ .\" 4.2BSD had a (never actually implemented) .\" .BR mremap (2) .\" call with completely different semantics. Cet appel système est spécifique à Linux et ne devrait pas être employé dans des programmes destinés à être portables. .SH NOTES Avant la version\ 2.4, la glibc ne fournissait pas la définition de \fBMREMAP_FIXED\fP et le prototype de \fBmremap\fP() ne permettait pas de passer le paramètre \fInew_address\fP. .PP Si \fBmremap\fP() est utilisé pour déplacer ou étendre une zone verrouillée avec \fBmlock\fP(2) ou équivalent, l'appel \fBmremap\fP() fera le maximum pour remplir la nouvelle zone mais il n'échouera pas avec \fBENOMEM\fP si la zone ne peut pas être remplie. .SH BOGUES .\" commit dba58d3b8c5045ad89c1c95d33d01451e3964db7 Avant Linux\ 4.14, si \fIold_size\fP valait zéro et si la projection à laquelle renvoyait \fIold_address\fP était une projection privée (\fBMAP_PRIVATE\fP de \fBmmap\fP(2)), \fBmremap\fP() créait une nouvelle projection privée sans lien avec celle d'origine. Ce comportement était intentionnel et probablement non prévu dans des applications de l'espace utilisateur (l'intention de \fBmremap\fP() étant de créer une nouvelle projection à partir de celle d'origine). Depuis Linux\ 4.14, \fBmremap\fP() échoue avec l'erreur \fBEINVAL\fP dans ce scénario. .SH "VOIR AUSSI" \fBbrk\fP(2), \fBgetpagesize\fP(2), \fBgetrlimit\fP(2), \fBmlock\fP(2), \fBmmap\fP(2), \fBsbrk\fP(2), \fBmalloc\fP(3), \fBrealloc\fP(3) .PP Votre manuel favori à propos de systèmes d'exploitation, pour des informations supplémentaires sur la mémoire paginée (par exemple \fIModern Operating Systems\fP de Andrew S.\& Tanenbaum, \fIInside Linux\fP par Randolf Bentson, \fIThe Design of the UNIX Operating System\fP par Maurice J.\& Bach) .SH COLOPHON Cette page fait partie de la publication\ 5.04 du projet \fIman\-pages\fP Linux. Une description du projet et des instructions pour signaler des anomalies et la dernière version de cette page peuvent être trouvées à l'adresse \%https://www.kernel.org/doc/man\-pages/. .SH TRADUCTION La traduction française de cette page de manuel a été créée par Christophe Blaess , Stéphan Rafin , Thierry Vignaud , François Micaux, Alain Portal , Jean-Philippe Guérard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas François , Florentin Duneau , Simon Paillard , Denis Barbier , David Prévot et Jean-Philippe MENGUAL . Cette traduction est une documentation libre ; veuillez vous reporter à la .UR https://www.gnu.org/licenses/gpl-3.0.html GNU General Public License version 3 .UE concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE. Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à .MT debian-l10n-french@lists.debian.org .ME .