Système d'exploitation - Gestion de la mémoire
La gestion de la mémoire est la fonctionnalité d'un système d'exploitation qui gère ou gère la mémoire principale et déplace les processus entre la mémoire principale et le disque pendant l'exécution. La gestion de la mémoire garde une trace de chaque emplacement de mémoire, qu'il soit alloué à un processus ou qu'il soit libre. Il vérifie la quantité de mémoire à allouer aux processus. Il décide quel processus recevra de la mémoire à quel moment. Il suit chaque fois qu'une partie de la mémoire est libérée ou non allouée et met à jour le statut en conséquence.
Ce didacticiel vous apprendra les concepts de base liés à la gestion de la mémoire.
Espace d'adressage de processus
L'espace d'adressage de processus est l'ensemble des adresses logiques qu'un processus référence dans son code. Par exemple, lorsque l'adressage 32 bits est utilisé, les adresses peuvent être comprises entre 0 et 0x7fffffff; c'est-à-dire 2 ^ 31 nombres possibles, pour une taille théorique totale de 2 gigaoctets.
Le système d'exploitation se charge de mapper les adresses logiques aux adresses physiques au moment de l'allocation de mémoire au programme. Il existe trois types d'adresses utilisées dans un programme avant et après l'allocation de la mémoire -
SN | Adresses de mémoire et description |
---|---|
1 | Symbolic addresses Les adresses utilisées dans un code source. Les noms de variables, les constantes et les étiquettes d'instructions sont les éléments de base de l'espace d'adressage symbolique. |
2 | Relative addresses Au moment de la compilation, un compilateur convertit les adresses symboliques en adresses relatives. |
3 | Physical addresses Le chargeur génère ces adresses au moment où un programme est chargé dans la mémoire principale. |
Les adresses virtuelles et physiques sont les mêmes dans les schémas de liaison d'adresses au moment de la compilation et au moment du chargement. Les adresses virtuelles et physiques diffèrent dans le schéma de liaison d'adresse au moment de l'exécution.
L'ensemble de toutes les adresses logiques générées par un programme est appelé logical address space. L'ensemble de toutes les adresses physiques correspondant à ces adresses logiques est appeléphysical address space.
Le mappage d'exécution de l'adresse virtuelle à l'adresse physique est effectué par l'unité de gestion de la mémoire (MMU) qui est un périphérique matériel. MMU utilise le mécanisme suivant pour convertir une adresse virtuelle en adresse physique.
La valeur du registre de base est ajoutée à chaque adresse générée par un processus utilisateur, qui est traitée comme un décalage au moment où elle est envoyée en mémoire. Par exemple, si la valeur du registre de base est 10000, alors une tentative par l'utilisateur d'utiliser l'emplacement d'adresse 100 sera réallouée dynamiquement à l'emplacement 10100.
Le programme utilisateur traite des adresses virtuelles; il ne voit jamais les vraies adresses physiques.
Chargement statique vs dynamique
Le choix entre le chargement statique ou dynamique doit être fait au moment du développement du programme informatique. Si vous devez charger votre programme de manière statique, au moment de la compilation, les programmes complets seront compilés et liés sans laisser aucune dépendance de programme ou de module externe. L'éditeur de liens combine le programme objet avec d'autres modules objet nécessaires dans un programme absolu, qui comprend également des adresses logiques.
Si vous écrivez un programme chargé dynamiquement, votre compilateur compilera le programme et pour tous les modules que vous souhaitez inclure dynamiquement, seules les références seront fournies et le reste du travail sera effectué au moment de l'exécution.
Au moment du chargement, avec static loading, le programme absolu (et les données) sont chargés en mémoire pour que l'exécution démarre.
Si vous utilisez dynamic loading, les routines dynamiques de la bibliothèque sont stockées sur un disque sous une forme réadressable et ne sont chargées en mémoire que lorsqu'elles sont nécessaires au programme.
Liaison statique vs dynamique
Comme expliqué ci-dessus, lorsque la liaison statique est utilisée, l'éditeur de liens combine tous les autres modules nécessaires à un programme en un seul programme exécutable pour éviter toute dépendance d'exécution.
Lorsque la liaison dynamique est utilisée, il n'est pas nécessaire de lier le module ou la bibliothèque réelle avec le programme, mais une référence au module dynamique est fournie au moment de la compilation et de la liaison. Les bibliothèques de liens dynamiques (DLL) dans Windows et les objets partagés sous Unix sont de bons exemples de bibliothèques dynamiques.
Échange
L'échange est un mécanisme dans lequel un processus peut être temporairement échangé hors de la mémoire principale (ou être déplacé) vers un stockage secondaire (disque) et rendre cette mémoire disponible pour d'autres processus. Plus tard, le système rétablit le processus du stockage secondaire vers la mémoire principale.
Bien que les performances soient généralement affectées par le processus de permutation, elles aident à exécuter plusieurs et gros processus en parallèle et c'est la raison Swapping is also known as a technique for memory compaction.
Le temps total nécessaire au processus d'échange comprend le temps nécessaire pour déplacer l'ensemble du processus sur un disque secondaire, puis pour le recopier en mémoire, ainsi que le temps nécessaire au processus pour regagner la mémoire principale.
Supposons que le processus utilisateur a une taille de 2048 Ko et que sur un disque dur standard où l'échange aura lieu a un taux de transfert de données d'environ 1 Mo par seconde. Le transfert réel du processus 1000K vers ou depuis la mémoire prendra
2048KB / 1024KB per second
= 2 seconds
= 2000 milliseconds
Compte tenu du temps d'entrée et de sortie, il faudra au total 4000 millisecondes plus d'autres frais généraux où le processus est en concurrence pour regagner la mémoire principale.
Allocation de mémoire
La mémoire principale a généralement deux partitions -
Low Memory - Le système d'exploitation réside dans cette mémoire.
High Memory - Les processus utilisateur sont conservés dans une mémoire élevée.
Le système d'exploitation utilise le mécanisme d'allocation de mémoire suivant.
SN | Allocation de mémoire et description |
---|---|
1 | Single-partition allocation Dans ce type d'allocation, un schéma de registre de relocalisation est utilisé pour protéger les processus utilisateur les uns des autres et contre la modification du code et des données du système d'exploitation. Le registre de relocalisation contient la valeur de la plus petite adresse physique tandis que le registre de limite contient une plage d'adresses logiques. Chaque adresse logique doit être inférieure au registre de limite. |
2 | Multiple-partition allocation Dans ce type d'allocation, la mémoire principale est divisée en un certain nombre de partitions de taille fixe où chaque partition ne doit contenir qu'un seul processus. Lorsqu'une partition est libre, un processus est sélectionné dans la file d'attente d'entrée et est chargé dans la partition libre. Lorsque le processus se termine, la partition devient disponible pour un autre processus. |
Fragmentation
Au fur et à mesure que les processus sont chargés et supprimés de la mémoire, l'espace mémoire libre est divisé en petits morceaux. Il arrive parfois que les processus ne puissent pas être alloués aux blocs de mémoire compte tenu de leur petite taille et que les blocs de mémoire restent inutilisés. Ce problème est connu sous le nom de fragmentation.
La fragmentation est de deux types -
SN | Fragmentation et description |
---|---|
1 | External fragmentation L'espace mémoire total est suffisant pour satisfaire une demande ou pour y résider un processus, mais il n'est pas contigu et ne peut donc pas être utilisé. |
2 | Internal fragmentation Le bloc de mémoire affecté au processus est plus grand. Une partie de la mémoire est laissée inutilisée, car elle ne peut pas être utilisée par un autre processus. |
Le diagramme suivant montre comment la fragmentation peut entraîner un gaspillage de mémoire et une technique de compactage peut être utilisée pour créer plus de mémoire libre à partir de la mémoire fragmentée -
La fragmentation externe peut être réduite en compactant ou en mélangeant le contenu de la mémoire pour placer toute la mémoire libre ensemble dans un grand bloc. Pour rendre le compactage possible, le déplacement doit être dynamique.
La fragmentation interne peut être réduite en attribuant efficacement la plus petite partition mais suffisamment grande pour le processus.
Pagination
Un ordinateur peut adresser plus de mémoire que la quantité physiquement installée sur le système. Cette mémoire supplémentaire est en fait appelée mémoire virtuelle et c'est une section d'un disque dur qui est configurée pour émuler la RAM de l'ordinateur. La technique de pagination joue un rôle important dans l'implémentation de la mémoire virtuelle.
La pagination est une technique de gestion de la mémoire dans laquelle l'espace d'adressage de processus est divisé en blocs de même taille appelés pages(la taille est la puissance de 2, entre 512 octets et 8192 octets). La taille du processus est mesurée en nombre de pages.
De même, la mémoire principale est divisée en petits blocs de mémoire (physique) de taille fixe appelés frames et la taille d'une trame est gardée la même que celle d'une page pour avoir une utilisation optimale de la mémoire principale et pour éviter la fragmentation externe.
Traduction d'adresse
L'adresse de la page est appelée logical address et représenté par page number et le offset.
Logical Address = Page number + page offset
L'adresse de trame est appelée physical address et représenté par un frame number et le offset.
Physical Address = Frame number + page offset
Une structure de données appelée page map table est utilisé pour garder une trace de la relation entre une page d'un processus et une trame de la mémoire physique.
Lorsque le système attribue un cadre à une page, il traduit cette adresse logique en une adresse physique et crée une entrée dans la table de pages à utiliser tout au long de l'exécution du programme.
Lorsqu'un processus doit être exécuté, ses pages correspondantes sont chargées dans toutes les trames de mémoire disponibles. Supposons que vous ayez un programme de 8 Ko mais que votre mémoire ne puisse accueillir que 5 Ko à un moment donné, alors le concept de pagination entrera en image. Lorsqu'un ordinateur manque de RAM, le système d'exploitation (OS) déplace les pages de mémoire inactives ou indésirables vers la mémoire secondaire pour libérer de la RAM pour d'autres processus et les ramène lorsque le programme en a besoin.
Ce processus se poursuit pendant toute l'exécution du programme où le système d'exploitation continue de supprimer les pages inactives de la mémoire principale et de les écrire sur la mémoire secondaire et de les ramener lorsque le programme l'exige.
Avantages et inconvénients de la pagination
Voici une liste des avantages et des inconvénients de la pagination -
La pagination réduit la fragmentation externe, mais souffre toujours de la fragmentation interne.
La pagination est simple à implémenter et considérée comme une technique efficace de gestion de la mémoire.
En raison de la taille égale des pages et des cadres, l'échange devient très facile.
La table des pages nécessite un espace mémoire supplémentaire, elle peut donc ne pas convenir à un système disposant de peu de RAM.
Segmentation
La segmentation est une technique de gestion de la mémoire dans laquelle chaque tâche est divisée en plusieurs segments de tailles différentes, un pour chaque module contenant des éléments exécutant des fonctions associées. Chaque segment est en fait un espace d'adressage logique différent du programme.
Lorsqu'un processus doit être exécuté, sa segmentation correspondante est chargée dans une mémoire non contiguë bien que chaque segment soit chargé dans un bloc contigu de mémoire disponible.
La gestion de la mémoire de segmentation fonctionne de manière très similaire à la pagination, mais ici les segments sont de longueur variable alors que les pages de pagination sont de taille fixe.
Un segment de programme contient la fonction principale du programme, les fonctions utilitaires, les structures de données, etc. Le système d'exploitation maintient unsegment map tablepour chaque processus et une liste des blocs de mémoire libres avec les numéros de segment, leur taille et les emplacements mémoire correspondants dans la mémoire principale. Pour chaque segment, la table stocke l'adresse de départ du segment et la longueur du segment. Une référence à un emplacement mémoire comprend une valeur qui identifie un segment et un décalage.