Exposé Sur Les Mémoires
Exposé Sur Les Mémoires
Exposé Sur Les Mémoires
Les mémoires
Une mémoire est un circuit à semi-conducteur permettant d’enregistrer,
de conserver et de restituer des informations (instructions et variables).
C’est cette capacité de mémorisation qui explique la polyvalence des
systèmes numériques et leur adaptabilité à de nombreuses situations.
Les informations peuvent être écrites ou lues. Il y a écriture lorsqu'on
enregistre des informations en mémoire, lecture lorsqu'on récupère des
informations précédemment enregistrées.
I- Organisation d’une mémoire
Une mémoire peut être représentée comme une armoire de rangement
constituée de différents tiroirs. Chaque tiroir représente alors une case
mémoire qui peut contenir un seul élément : des données. Le nombre
de cases mémoires pouvant être très élevé, il est alors nécessaire de
pouvoir les identifier par un numéro. Ce numéro est appelé adresse.
Chaque donnée devient alors accessible grâce à son adresse
Adresse Case mémoire
7 = 111
6 = 110
5 = 101
4 = 100
3 = 011
2 = 010
1 = 001
0 = 000 0001 1010
Avec une adresse de n bits il est possible de référencer au plus 2n cases
mémoire. Chaque case est remplie par un mot de données (sa longueur
m est toujours une puissance de 2). Le nombre de fils d’adresses d’un
boîtier mémoire définit donc le nombre de cases mémoire que comprend
le boîtier. Le nombre de fils de données définit la taille des données que
l’on peut sauvegarder dans chaque case mémoire.
En plus du bus d’adresses et du bus de données, un boîtier mémoire
comprend une entrée de commande qui permet de définir le type
d’action que l’on effectue avec la mémoire (lecture/écriture) et une entrée
de sélection qui permet de mettre les entrées/sorties du boîtier en haute
impédance. On peut donc schématiser un circuit mémoire par la figure
suivante où l’on peut distinguer :
les entrées d’adresses
les entrées de données
les sorties de données
les entrées de commandes :
- une entrée de sélection de lecture ou d’écriture. (R/W)
- une entrée de sélection du circuit. (CS)
Chapitre
3
Adresses
(N bits)
R/W Mémoire Données (m bits)
CS
10
Une opération de lecture ou d’écriture de la mémoire suit toujours le
même cycle :
1. sélection de l’adresse
2. choix de l’opération à effectuer (R/W)
3. sélection de la mémoire (CS = 0)
4. lecture ou écriture la donnée
Remarque :
Les entrées et sorties de données sont très souvent regroupées sur des
bornes bidirectionnelles.
3.2 Caractéristiques d’une mémoire
La capacité : c’est le nombre total de bits que contient la mémoire.
Elle s’exprime aussi souvent en octet.
Le format des données : c’est le nombre de bits que l’on peut
mémoriser par case mémoire. On dit aussi que c’est la largeur du mot
mémorisable.
Le temps d’accès : c’est le temps qui s'écoule entre l'instant où a été
lancée une opération de lecture/écriture en mémoire et l'instant où la
première information est disponible sur le bus de données.
Le temps de cycle : il représente l'intervalle minimum qui doit séparer
deux demandes successives de lecture ou d'écriture.
Le débit : c’est le nombre maximum d'informations lues ou écrites par
seconde.
Volatilité : elle caractérise la permanence des informations dans la
mémoire. L'information stockée est volatile si elle risque d'être altérée
par un défaut d'alimentation électrique et non volatile dans le cas
contraire.
Exemple : Chronogramme d’un cycle de lecture
Remarque :
Les mémoires utilisées pour réaliser la mémoire principale d’un système
à microprocesseur sont des mémoires à semi-conducteur. On a vu que
dans ce type de mémoire, on accède directement à n'importe quelle
information dont on connaît l'adresse et que le temps mis pour obtenir
cette information ne dépend pas de l'adresse. On dira que l'accès à une
telle mémoire est aléatoire ou direct.
A l'inverse, pour accéder à une information sur bande magnétique, il faut
dérouler la bande en repérant tous les enregistrements jusqu'à ce que
l'on trouve celui que l'on désire. On dit alors que l'accès à l'information
est séquentiel. Le temps d'accès est variable selon la position de
l'information recherchée. L'accès peut encore être semi-séquentiel :
combinaison des accès direct et séquentiel.
Pour un disque magnétique par exemple l'accès à la piste est direct, puis
l'accès au secteur est séquentiel.
BUS @
BUS D
Taccès
R/W
CS
Tcycle
Données accessibles
@x
Dx
11
3.3 Différents types de mémoire
3.3.1 Les mémoires vives (RAM)
Une mémoire vive sert au stockage temporaire de données. Elle doit
avoir un temps de cycle très court pour ne pas ralentir le
microprocesseur. Les mémoires vives sont en général volatiles : elles
perdent leurs informations en cas de coupure d'alimentation. Certaines
d'entre elles, ayant une faible consommation, peuvent être rendues non
volatiles par l'adjonction d'une batterie. Il existe deux grandes familles de
mémoires RAM (Random Acces Memory : mémoire à accès aléatoire) :
Les RAM statiques
Les RAM dynamiques
3.3.1.1 Les RAM statiques
Le bit mémoire d'une RAM statique (SRAM) est composé d'une bascule.
Chaque bascule contient entre 4 et 6 transistors.
3.3.1.2 Les RAM dynamiques
Dans les RAM dynamiques (DRAM), l'information est mémorisée sous la
forme d'une charge électrique stockée dans un condensateur (capacité
grille substrat d'un transistor MOS).
Avantages :
Cette technique permet une plus grande densité d'intégration, car un
point mémoire nécessite environ quatre fois moins de transistors que
dans une mémoire statique. Sa consommation s’en retrouve donc aussi
très réduite.
Inconvénients :
La présence de courants de fuite dans le condensateur contribue à sa
décharge. Ainsi, l’information est perdue si on ne la régénère pas
périodiquement (charge du condensateur). Les RAM dynamiques
doivent donc être rafraîchies régulièrement pour entretenir la
mémorisation : il s'agit de lire l'information et de la recharger. Ce
rafraîchissement indispensable a plusieurs conséquences :
- il complique la gestion des mémoires dynamiques car il faut tenir
compte des actions de rafraîchissement qui sont prioritaires.
- la durée de ces actions augmente le temps d'accès aux informations.
@7
@6
@5
@4
@3
@2
@1
@0
D7
D6 D4
D3
D2
D5 D1
D0
@7
@6
@5
@4
@3
@2
@1
@0
D7
D6 D4
D3
D2
D5 D1
D0
12
D’autre part, la lecture de l’information est destructive. En effet, elle se
fait par décharge de la capacité du point mémoire lorsque celle-ci est
chargée. Donc toute lecture doit être suivie d’une réécriture.
3.3.1.3 Conclusions
En général les mémoires dynamiques, qui offrent une plus grande
densité d'information et un coût par bit plus faible, sont utilisées pour la
mémoire centrale, alors que les mémoires statiques, plus rapides, sont
utilisées lorsque le facteur vitesse est critique, notamment pour des
mémoires de petite taille comme les caches et les registres.
Remarque :
Voici un historique de quelques DRAM qui ont ou sont utilisées dans les
PC :
• La DRAM FPM (Fast Page Mode, 1987) : Elle permet d'accéder plus
rapidement à des données en introduisant la notion de page mémoire.
(33 à 50 Mhz)
• La DRAM EDO (Extended Data Out, 1995) : Les composants de cette
mémoire permettent de conserver plus longtemps l'information, on peut
donc ainsi espacer les cycles de rafraîchissement. Elle apporte aussi la
possibilité d’anticiper sur le prochain cycle mémoire. (33 à 50 Mhz)
• La DRAM BEDO (Bursted EDO): On n'adresse plus chaque unité de
mémoire individuellement lorsqu'il faut y lire ou y écrire des données. On
se contente de transmettre l'adresse de départ du processus de
lecture/écriture et la longueur du bloc de données (Burst). Ce procédé
permet de gagner beaucoup de temps, notamment avec les grands
paquets de données tels qu'on en manipule avec les applications
modernes. (66 Mhz)
• La Synchronous DRAM (SDRAM, 1997) : La mémoire SDRAM a pour
particularité de se synchroniser sur une horloge. Les mémoires FPM,
EDO étaient des mémoires asynchrones et elle induisait des temps
d'attentes lors de la synchronisation. Elle se compose en interne de deux
bancs de mémoire et des données peuvent être lues alternativement sur
l'un puis sur l'autre de ces bancs grâce à un procédé d'entrelacement
spécial. Le protocole d'attente devient donc tout à fait inutile. Cela lui
permet de supporter des fréquences plus élevées qu’avant (100 Mhz).
• La DDR-I ou DDR-SDRAM (Double Data Rate Synchronous DRAM,
2000) : La DDR-SDRAM permet de recevoir ou d'envoyer des données
lors du front montant et du front descendant de l’horloge.
(133 à 200 MHz)
3.3.2 Les mémoires mortes (ROM)
Pour certaines applications, il est nécessaire de pouvoir conserver des
informations de façon permanente même lorsque l'alimentation
électrique est interrompue. On utilise alors des mémoires mortes ou
mémoires à lecture seule (ROM : Read Only Memory). Ces mémoires
sont non volatiles.
Ces mémoires, contrairement aux RAM, ne peuvent être que lue.
L’inscription en mémoire des données reste possible mais est appelée
programmation. Suivant le type de ROM, la méthode de programmation
changera. Il existe donc plusieurs types de ROM :
ROM
PROM
EPROM
EEPROM
FLASH EPROM.
13
3.3.2.1 LA ROM
Elle est programmée par le fabricant et son contenu ne peut plus être ni
modifié. Ni effacé par l'utilisateur.
Structure :
Cette mémoire est composée d'une matrice dont la programmation
s’effectue en reliant les lignes aux colonnes par des diodes. L'adresse
permet de sélectionner une ligne de la matrice et les données sont alors
reçues sur les colonnes (le nombre de colonnes fixant la taille des mots
mémoire).
Programmation :
L'utilisateur doit fournir au constructeur un masque indiquant les
emplacements de la diode dans matrice.
Avantages :
Densité élevée
Non volatile
Mémoire rapide
Inconvénients :
Écriture impossible
Modification impossible (toute erreur est fatale).
Délai de fabrication (3 à 6 semaines)
Obligation de grandes quantités en raison du coût élevé qu'entraîne la
production du masque et le processus de fabrication.
3.3.2.2 La PROM
C’est une ROM qui peut être programmée une seule fois par l'utilisateur
(Programmable ROM). La programmation est réalisée à partir d’un
programmateur spécifique.
Structure :
Les liaisons à diodes de la ROM sont remplacées par des fusibles
pouvant être détruits ou des jonctions pouvant être court-circuitées.
Programmation :
Les PROM à fusible sont livrés avec toutes les lignes connectées aux
colonnes (0 en chaque point mémoire). Le processus de programmation
consiste donc à programmer les emplacements des ‘’1’’ en générant des
impulsions de courants par l’intermédiaire du programmateur ; les
fusibles situés aux points mémoires sélectionnés se retrouvant donc
détruits.
Le principe est identique dans les PROM à jonctions sauf que les lignes
et les colonnes sont déconnectées (1 en chaque point mémoire). Le
processus de programmation consiste donc à programmer les
emplacements des ‘’0’’ en générant des impulsions de courants par
l’intermédiaire du programmateur ; les jonctions situées aux points
mémoires sélectionnés se retrouvant court-circuitées par effet
d’avalanche.
Adresse
+V
Données
1000
14
Avantages :
Idem ROM
Claquage en quelques minutes
Coût relativement faible
Inconvénients :
Modification impossible (toute erreur est fatale).
3.3.2.3 L’EPROM ou UV-EPROM
Pour faciliter la mise au point d'un programme ou tout simplement
permettre une erreur de programmation, il est intéressant de pouvoir
reprogrammer une PROM. La technique de claquage utilisée dans
celles-ci ne le permet évidemment pas. L'EPROM (Erasable
Programmable ROM) est une PROM qui peut être effacée.
Structure
Dans une EPROM, le point mémoire est réalisé à partir d’un transistor
FAMOS (Floating gate Avalanche injection Metal Oxyde Silicium). Ce
transistor MOS a été introduit par Intel en 1971 et a la particularité de
posséder une grille flottante.
Programmation
La programmation consiste à piéger des charges dans la grille flottante.
Pour cela, il faut tout d’abord appliquer une très forte tension entre Grille
et Source. Si l’on applique ensuite une tension entre D et S, le canal
devient conducteur. Mais comme la tension Grille-Source est très
importante, les électrons sont déviés du canal vers la grille flottante et
capturés par celle-ci. Cette charge se maintient une dizaine d'années en
condition normale.
L’exposition d’une vingtaine de minutes à un rayonnement ultraviolet
permet d’annuler la charge stockée dans la grille flottante. Cet
effacement est reproductible plus d’un millier de fois. Les boîtiers des
EPROM se caractérisent donc par la présence d’une petite fenêtre
transparente en quartz qui assure le passage des UV. Afin d’éviter toute
perte accidentelle de l’information, il faut obturer la fenêtre d’effacement
lors de l’utilisation.
Avantages :
Reprogrammable et non Volatile
Inconvénients :
Impossible de sélectionner une seule cellule à effacer
Impossible d’effacer la mémoire in-situ.
l’écriture est beaucoup plus lente que sur une RAM. (environ 1000x)
3.3.2.4 L’EEPROM
L’EEPROM (Electically EPROM) est une mémoire programmable et
effaçable électriquement.
Elle répond ainsi à l’inconvénient principal de l’EPROM et peut être
programmée in situ.
P
NN
SGD
Grille flottante
Canal
15
Structure
Dans une EEPROM, le point mémoire est réalisé à partir d’un transistor
SAMOS reprenant le même principe que le FAMOS sauf que l’épaisseur
entre les deux grilles est beaucoup plus faible.
Programmation
Une forte tension électrique appliquée entre grille et source conduit à la
programmation de la mémoire. Une forte tension inverse provoquera la
libération des électrons et donc l’effacement de la mémoire.
Avantages :
Comportement d'une RAM non Volatile.
Programmation et effacement mot par mot possible.
Inconvénients :
Très lente pour une utilisation en RAM.
Coût de réalisation.
3.3.2.5 La FLASH EPROM
La mémoire Flash s'apparente à la technologie de l’EEPROM. Elle est
programmable et effaçable électriquement comme les EEPROM.
Structure
Il existe deux technologie différentes qui se différencient par
l’organisation de leurs réseaux mémoire : l’architecture NOR et
NAND. L’architecture NOR propose un assemblage des cellules
élémentaires de mémorisation en parallèle avec les lignes de sélection
comme dans une EEPROM classique. L’architecture NAND propose un
assemblage en série de ces mêmes cellules avec les lignes de sélection.
D’un point de vue pratique, la différence majeure entre NOR et NAND
tient à leurs interfaces. Alors qu’une NOR dispose de bus d’adresses et
de données dédiés, la NAND est dotée d’une interface d’E/S indirecte. .
Par contre, la structure NAND autorise une implantation plus dense
grâce à une taille de cellule approximativement 40 % plus petite que la
structure NOR.
Programmation
Si NOR et NAND exploitent toutes deux le même principe de stockage
de charges dans la grille flottante d’un transistor, l’organisation de leur
réseau mémoire n’offre pas la même souplesse d’utilisation. Les Flash
NOR autorisent un adressage aléatoire qui permet de la programmer
octet par octet alors que la Flash NAND autorise un accès séquentiel
aux données et permettra seulement une programmation par secteur
comme sur un disque dur.
Avantages
Flash NOR :
Comportement d'une RAM non Volatile.
Programmation et effacement mot par mot possible.
Temps d’accès faible.
@7
@6
@5
@4
@3
@2
@1
@0
D7
D6 D4
D3
D2
D5 D1
D0
Architecture NOR
Secteur 1 = @0 à n
Architecture NAND
@0@n
16
Flash NAND :
Comportement d'une RAM non Volatile.
Forte densité d’intégration coût réduit.
Rapidité de l’écriture/lecture par paquet
Consommation réduite.
Inconvénients
Flash NOR :
Lenteur de l’écriture/lecture par paquet.
coût.
Flash NAND :
Ecriture/lecture par octet impossible.
Interface E/S indirecte
La Flash EPROM a connu un essor très important ces dernières années
avec le boom de la téléphonie portable et des appareils multimédia
(PDA, appareil photo numérique, lecteur MP3, etc...).
3.4 Critères de choix d’une mémoire
Les principaux critères à retenir sont :
Capacité
vitesse
Consommation
Coût
3.5 Notion de hiérarchie mémoire
Une mémoire idéale serait une mémoire de grande capacité, capable de
stocker un maximum d’informations et possédant un temps d’accès très
faible afin de pouvoir travailler rapidement sur ces informations. Mais il
se trouve que les mémoires de grande capacité sont souvent très lente
et que les mémoires rapides sont très chères. Et pourtant, la vitesse
d’accès à la mémoire conditionne dans une large mesure les
performances d’un système. En effet, c’est là que se trouve le goulot
d’étranglement entre un microprocesseur capable de traiter des
informations très rapidement et une mémoire beaucoup plus lente (ex :
processeur actuel à 3Ghz et mémoire à 400MHz). Or, on n’a jamais
besoin de toutes les informations au même moment. Afin d’obtenir le
meilleur compromis coût-performance, on définit donc une hiérarchie
mémoire. On utilise des mémoires de faible capacité mais très rapide
pour stocker les informations dont le microprocesseur se sert le plus et
on utilise des mémoires de capacité importante mais beaucoup plus
lente pour stocker les informations dont le microprocesseur se sert le
moins. Ainsi, plus on s’éloigne du microprocesseur et plus la capacité et
le temps d’accès des mémoires vont augmenter.
Registre
Mémoire cache
Mémoire principale
Mémoire d’appui
Mémoire de masse
+
vitesse
+
Capacité
1 ns < 400 o
8 ko à 4 Mo suivant
Les niveaux
5 ns
10 ns Jusqu’à 1 Go
2 à 8 Mo
5 ms 200 Go
17
Les registres sont les éléments de mémoire les plus rapides. Ils sont
situés au niveau du processeur et servent au stockage des opérandes et
des résultats intermédiaires.
La mémoire cache est une mémoire rapide de faible capacité
destinée à accélérer l’accès à la mémoire centrale en stockant les
données les plus utilisées.
La mémoire principale est l’organe principal de rangement des
informations. Elle contient les programmes (instructions et données) et
est plus lente que les deux mémoires précédentes.
La mémoire d’appui sert de mémoire intermédiaire entre la mémoire
centrale et les mémoires de masse. Elle joue le même rôle que la
mémoire cache.
La mémoire de masse est une mémoire périphérique de grande
capacité utilisée pour le stockage permanent ou la sauvegarde des
informations. Elle utilise pour cela des supports magnétiques (disque
dur, ZIP) ou optiques (CDROM, DVDROM