Loading AI tools
accès aux données conservées en mémoire. De Wikipédia, l'encyclopédie libre
L’adressage mémoire est, en électronique et en informatique, la façon dont se fait l'accès aux données conservées en mémoire[1]. Une adresse mémoire est un nombre entier naturel (rarement une autre sorte d'identifiant) qui désigne une zone particulière de la mémoire, ou juste le début d'une zone. Le plus souvent, une donnée peut être lue ou écrite. La mémoire peut être temporaire (mémoire vive) pour le travail ou au contraire durable (mémoire non volatile) pour le stockage.
L'immense majorité des programmes informatiques fait usage de la mémoire lors de son exécution. Le stockage temporaire d'une donnée (une variable) implique l'accès à la mémoire vive : dans ce cas, c'est le processeur qui écrit sur le bus. Lors d'un accès à un composant DMA (par exemple un disque dur), c'est le contrôleur DMA qui, cette fois, agit directement sur le bus système.
Les ordinateurs assez puissants pour faire fonctionner de nombreux programmes simultanément sont généralement équipés d'une unité de gestion de mémoire (MMU) capable de traduire à la volée les adresses mémoire envoyées par le processeur à la mémoire. C'est notamment le cas des ordinateurs personnels depuis les années 1990. Lorsqu'une telle unité est en fonction, les adresses émises par le processeur sont alors des adresses virtuelles, et les adresses traduites qui arrivent à la mémoire sont des adresses physiques[2].
Le système d'exploitation peut notamment programmer l'unité de gestion de mémoire pour :
Les composants périphériques jouissant d'un accès direct à la mémoire peuvent aussi voir leurs adresses traduites par une unité de gestion de mémoire dédiée (IOMMU).
L'interface utilisée est dans la plupart des cas un bus, c'est-à-dire un ensemble de fils destinés à une utilisation particulière (ici l'accès à la mémoire).
Sur N fils, on peut coder 2N valeurs. Ainsi, en précisant la largeur du bus d'adresse, en nombre de bits (ou fils), on indique la capacité mémoire maximum accessible par le processeur[4] (la taille de son espace d'adressage).
En plus des fils codant l'adresse, la mémoire vive nécessite au moins un fil supplémentaire indiquant l'opération qui sera faite sur la mémoire : lecture ou écriture.
Il est possible de multiplexer le bus d'adresse avec le bus de données, en mettant en commun un certain nombre de fils, sachant qu'un signal supplémentaire devra être généré pour savoir comment interpréter les valeurs binaires circulant sur ces fils (adresse ou données). Un exemple de processeurs avec bus multiplexé : les 8086 ou 8088 d'Intel.
Un bus d'adresse trop petit, donc un adressage mémoire restreint, a été l'un des facteurs déterminants dans la disparition de certaines lignées d'ordinateurs. Par exemple, le PDP-10, une machine 36 bits dont l'espace d'adressage n'était que de 18 bits (256 kibioctets), n'a jamais eu de successeur. La gamme de mini-ordinateurs PDP-11 de DEC a été remplacée par les VAX, ce qui est d'ailleurs l'abréviation de Virtual Address Extension.
On parle d'adressage indirect lorsque, pour accéder à une donnée, on récupère son adresse dans une variable[1] (ou segment de mémoire). C'est donc un adressage par référence au contenu de cette autre variable. L'adressage indirect est la méthode la plus pratique pour accéder séquentiellement à des données stockées de façon régulière, par un mécanisme de boucle : on peut ainsi balayer toute une zone de données (composantes d'un vecteur, d'un tableau, d'un arbre, etc.) en faisant varier un indice qui détermine la position[5],[6]. Dans les microprocesseurs, cette technique était réalisée grâce aux registres d'index, qui permettent de construire l'adresse mémoire sur une seule instruction-machine.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.