SHM_OVERVIEW
Section : Manuel du programmeur Linux (
7)
Mise à jour de la version anglaise : 25 juin 2008
Index
Menu principal
NOM
shm_overview - Panorama de la mémoire partagée POSIX
DESCRIPTION
L'API de mémoire partagée POSIX permet aux processus de communiquer
entre eux en partageant une région de la mémoire.
Les interfaces utilisées dans l'API sont :
- shm_open(3)
-
Créer et ouvrir un nouvel objet, ou ouvrir un objet existant.
Elle est analogue à
open(2).
La fonction renvoie un descripteur de fichiers qui pourra être
utilisé par les interfaces décrites ci-dessous.
- ftruncate(2)
-
Définir la taille de l'objet en mémoire partagée.
(Un objet nouvellement créé en mémoire partagée a une taille nulle.)
- mmap(2)
-
Projeter l'objet en mémoire partagée dans l'espace d'adresses virtuel
du processus appelant.
- munmap(2)
-
Déprojeter l'objet en mémoire partagée de l'espace d'adresses virtuel
du processus appelant.
- shm_unlink(3)
-
Supprimer le nom d'un objet en mémoire partagée.
- close(2)
-
Fermer le descripteur de fichier alloué avec
shm_open(3)
lorsqu'on en a plus besoin.
- fstat(2)
-
Obtenir une structure
stat
décrivant l'objet en mémoire partagée.
Parmi les informations renvoyées par cet appel,
on trouve la taille de l'objet
(st_size),
ses permissions
(st_mode),
son propriétaire
(st_uid)
et le groupe
(st_gid)
auquel il appartient.
- fchown(2)
-
Pour modifier l'appartenance d'un objet en mémoire partagée.
- fchmod(2)
-
Pour modifier les permissions d'accès d'un objet en mémoire partagée.
Versions
La mémoire partagée POSIX est gérée depuis Linux 2.4 et la glibc 2.2.
Persistence
Les objets en mémoire partagée POSIX ont la persistence du noyau :
un objet en mémoire partagée existera jusqu'à ce que le système soit éteint,
ou bien jusqu'à ce que tous les processus aient déprojetés l'objet
et que celui-ci ait été supprimé avec
shm_unlink(3).
Édition de liens
Les programmes utilisant l'API de mémoire partagée POSIX doit être
compilé avec
cc -lrt
pour le lier à la bibliothèque temps réel
librt.
Accéder aux objets en mémoire partagée par le système de fichiers
Sous linux, les objets en mémoire partagée sont créés sur un système
de fichiers virtuel
(
tmpfs),
généralement monté sur
/dev/shm.
Depuis le noyau 2.6.19, Linux gère l'utilisation des listes de contrôle
d'accès (ACL) pour contrôler les permissions d'accès aux objets
du système de fichiers virtuel.
CONFORMITÉ
POSIX.1-2001.
NOTES
Typiquement, les processus doivent synchroniser leur accès à un objet
en mémoire partagée en utilisant, par exemple, les sémaphores POSIX.
La mémoire partagée System V
(shmget(2),
shmop(2),
etc.) est une ancienne API de sémaphores.
La mémoire partagée POSIX offre une interface plus simple et mieux conçue ;
d'un autre coté, la mémoire partagée POSIX est moins largement disponible
(particulièrement sur d'anciens systèmes) que la mémoire partagée System V.
VOIR AUSSI
fchmod(2),
fchown(2),
fstat(2),
ftruncate(2),
mmap(2),
mprotect(2),
munmap(2),
shmget(2),
shmop(2),
shm_open(3),
shm_unlink(3),
sem_overview(7)
TRADUCTION
Ce document est une traduction réalisée par Alain Portal
<aportal AT univ-montp2 DOT fr> le 4 juillet 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 7 shm_overview ».
N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute
erreur dans cette page de manuel.
Index
- NOM
-
- DESCRIPTION
-
- Versions
-
- Persistence
-
- Édition de liens
-
- Accéder aux objets en mémoire partagée par le système de fichiers
-
- CONFORMITÉ
-
- NOTES
-
- VOIR AUSSI
-
- TRADUCTION
-
Dernière mise à jour : 17 juillet 2008