



## Polytech Dijon FISA IOT 5A

Compte rendu projet VHDL

---

### Contrôleur SRAM

---

Auteur :  
HELLE Evan

Enseignant :  
DUBOIS Julien



2025-2026

# Sommaire

|                                                                        |          |
|------------------------------------------------------------------------|----------|
| <b>1 Compte Rendu</b>                                                  | <b>5</b> |
| 1.1 Introduction . . . . .                                             | 5        |
| 1.2 IO Buffer . . . . .                                                | 5        |
| 1.2.1 Fonctionnement . . . . .                                         | 5        |
| 1.2.2 Test Bench . . . . .                                             | 6        |
| 1.3 Contrôleur SRAM . . . . .                                          | 8        |
| 1.3.1 Finished State Machine . . . . .                                 | 9        |
| 1.3.2 Implementation du Contrôleur SRAM . . . . .                      | 11       |
| 1.3.3 Test bench . . . . .                                             | 12       |
| 1.4 Mode Burst . . . . .                                               | 14       |
| 1.4.1 Implémentation du mode Burst . . . . .                           | 14       |
| 1.5 Estimation de la durée d'exécution du contrôleur<br>SRAM . . . . . | 23       |
| 1.5.1 Accès en mode lecture et écriture simple . .                     | 23       |
| 1.5.2 Accès en mode Burst . . . . .                                    | 24       |
| 1.5.3 Limites de l'estimation . . . . .                                | 24       |
| 1.6 Conclusion . . . . .                                               | 24       |

# Table des Figures

|      |                                                                 |    |
|------|-----------------------------------------------------------------|----|
| 1.1  | IO buffer . . . . .                                             | 5  |
| 1.2  | Extrait énoncé projet . . . . .                                 | 6  |
| 1.3  | Simulation IO Buffer . . . . .                                  | 8  |
| 1.4  | Haute impédance à la lecture de la donnée . . . . .             | 8  |
| 1.5  | Contrôleur SRAM . . . . .                                       | 9  |
| 1.6  | FSM . . . . .                                                   | 10 |
| 1.7  | Simulation Test Bench Contrôleur SRAM . . . . .                 | 13 |
| 1.8  | Simulation après ajout des signaux CE_n, OE_n et Ld_n . . . . . | 16 |
| 1.9  | Simulation write mode burst . . . . .                           | 20 |
| 1.10 | Simulation read mode burst . . . . .                            | 22 |

Ce document a été réalisé avec L<sup>A</sup>T<sub>E</sub>X.

# 1 Compte Rendu

## 1.1 Introduction

Ce projet consiste à concevoir et implémenter en VHDL un contrôleur pour une mémoire SRAM de type mt55l512y36f, dont le modèle VHDL est fourni par le fabricant.

L'objectif est de permettre les opérations de lecture et d'écriture tout en respectant les contraintes temporelles et les spécifications électriques du composant.

Le contrôleur recevra les données via une interface d'entrée-sortie (IO Buffer) et assurera la communication avec la mémoire SRAM à travers une interface dédiée. Son fonctionnement sera structuré autour d'une machine à états finis (FSM) afin de gérer de manière séquentielle et fiable les différentes phases d'accès mémoire.

Le projet inclura également la réalisation de `test bench` destinés à valider le comportement et la conformité de chaque élément du contrôleur.

## 1.2 IO Buffer

### 1.2.1 Fonctionnement

Un IO Buffer est un composant matériel utilisé dans les circuits pour gérer les signaux d'entrée et de sortie entre le circuit et le monde extérieur.

L'implémentation de L'IO Buffer que nous allons utiliser nous nous a été fourni.

Voici la représentation schématique de l'IO Buffer que nous allons utiliser dans notre projet :



Figure 1.1: IO buffer

L'IO Buffer est composé de plusieurs entrées et sorties :

- **I** : Donnée d'entrée (input data)
- **O** : Donnée de sortie (output data)
- **T** : Trigger, permet de contrôler le mode de l'IO Buffer (entrée ou sortie qui servira à gerer l'écriture ou la lecture dans notre cas)
- **IO** : Bus de données bidirectionnel (data bus)

### 1.2.2 Test Bench

L'objectif de faire un test bench est de vérifier le bon fonctionnement de l'IO Buffer avec la SRAM.

De plus cela permettra de comprendre son fonctionnement avant de l'intégrer dans le projet final.

Il est important de faire ce test car il est nécessaire d'avoir un décalage entre la donnée et les signaux de contrôle au niveau de la SRAM.



```

14  SA          <= "000"&x"0001";
15  Trig      <= '0'; -- écriture à l'adresse 1
16  wait for 1*(TCLKL); -- pour travailler sur front montant
17  ENTREE   <= (others => '1'); -- décalage de la donnée d'un cycle
18                  --par rapport à l'adresse et la commande
19
20
21  wait for 2*(TCLKL+TCLKH);
22  SA          <= "000"&x"0002"; -- écriture à l'adresse 2
23  wait for 1*(TCLKL+TCLKH);
24  ENTREE   <= ENTREE + 1;-- décalage de la donnée d'un cycle par
25                  -- rapport à l'adresse et la commande
26
27  wait for 2*(TCLKH+TCLKL);
28  SA          <= "000"&x"0001"; -- lecture à l'adresse 1
29  Trig <= '1';
30  wait for 2*(TCLKH+TCLKL);
31  SA          <= "000"&x"0002"; -- lecture à l'adresse 2
32
33  wait; -- will wait forever
34 END PROCESS;

```

---

Ici la donnée est bien décalée d'un cycle par rapport à l'adresse et la commande. Quand le trigger est à 0, on est en écriture, et quand il est à 1, on est en lecture. C'est le cas pour la SRAM et l'IO buffer. Donc nous avons connecter par un fil ces deux I/O.

```

1  SRAM1 : mt551512y36f port map
2  (DQ, SA, '0', CLKO_SRAM, nCKE, nADVLD, '0',
3  '0', '0', '0', Trig, nOE, nCE, nCE2, CE2, '0');
4
5  IOB: for I in 0 to 35 generate
6  IOBx: IOBUF_F_16 port map(
7  O => SORTIE(I),
8  IO => DQ(I),
9  I => ENTREE(I),
10 T => Trig
11 );
12 end generate;

```

---

## Simulation

Voici le résultatat de la simulation :



Figure 1.3: Simulation IO Buffer

Les données sont bien écrites aux bonnes adresses (1 et 2) et lues correctement par la suite.

Au passage à la lecture, le bus bidirectionnel passe en haute impédance, ce qui est le comportement attendu.

Voici un zoom sur le passage en haute impédance :



Figure 1.4: Haute impédance à la lecture de la donnée

### 1.3 Contrôleur SRAM

Maintenant que nous avons validé le bon fonctionnement de l'IO buffer connecté à la SRAM, nous allons implémenter le contrôleur de la SRAM. Celui-ci sera responsable de la gestion des opérations de lecture et d'écriture vers la mémoire SRAM en fonction des signaux d'entrée.

Son fonctionnement sera basé sur une machine à états finis (FSM) qui gérera les différents états nécessaires pour effectuer les opérations de lecture et d'écriture.

un IO buffer sera également présent pour interfaçer les données entre le contrôleur et la SRAM.



Figure 1.5: Contrôleur SRAM

Coté utilisateur, Les signaux ont été ajustés pour tensir sur un nombre d'octets complet:

- **User\_address** : Adresse de 19 bits
- **User\_data\_in** : Données d'entrée de 32 bits
- **User\_data\_out** : Données de sortie de 32 bits
- **Ctrl** : Signal d'écriture/lecture (1 bit)

Nous avons fait le choix de laisser l'adresse sur 19 bits pour pouvoir adresser toute la mémoire SRAM.

D'un point de vue utilisateur, nous aurions pu choisir de mettre l'adresse sur 16 bits pour avoir un nombre complet d'octet.

### 1.3.1 Finished State Machine

D'après la page 11 de la datasheet de la SRAM :



Figure 1.6: FSM

Pour le moment, nous n'allons pas implémenter le mode Burst.  
Cela signifie que les signaux MODE (LBO#) et ADV/LV# seront à 0.

## Implementation FSM

```

1 process(Clk,reset)
2 begin
3 if reset = '1' then
4     state <= INIT;
5
6 elsif Clk'EVENT and Clk = '1' then
7     case state is
8         When INIT =>
9             state <= IDLE;
10
11        when IDLE =>
12            if Ctrl ='1' AND Start ='1' then
13                state <= READ;
14            elsif Ctrl ='0' AND Start ='1' then
15                state <= WRITE;
16            else
17                state <= IDLE;
18            end if;
19
20        when READ =>
21            if Ctrl ='1' AND Start ='1' then
22                state <= READ;
23            elsif Ctrl ='0' AND Start ='1' then
24                state <= WRITE;

```

```

25      else
26          state <= IDLE;
27      end if;
28
29      when WRITE =>
30          if Ctrl ='1' AND Start ='1' then
31              state <= READ;
32          elsif Ctrl ='0' AND Start ='1' then
33              state <= WRITE;
34          else
35              state <= IDLE;
36          end if;
37      end case;
38  end if;
39 end process;

```

---

### 1.3.2 Implementation du Contrôleur SRAM

D'après le sujet, plusieurs signaux seront à mettre à 0 :

- ZZ sooze mode : basse consommation. 1 pour activer
- nCKE : clock enable si mis à 0
- nBWA
- nBWB
- nBWC
- nBWD : Byte write enable. permet de selectionner quels octets sont écrits. Mis à 0 pour écrire tous les octets.

Ces signaux seront mis à 0 dans un état précédent l'état IDLE qui est l'état INIT.

Afin de creer un déclalge d'horloge entre la donnée utilisateur, l'adresse et la commande, nous allons utiliser des bascules D La manière la plus simple d'utiliser des bascules D est de assaigner une entrée à un signal interne du composant dans un processus sensible aux fronts de l'horloge.

Ici, sur front monant, nous allons décaler la donnée utilisateur de deux cycles d'horloge et recopier l'adresse utilisateur sur l'adresse de la SRAM.

Sur front descendant, nous allons ajouter les bits de parité à la donnée avant de l'envoyer à la SRAM et renvoyer la donnée lue de la SRAM vers la sortie utilisateur.

---

```

1 process(Clk)
2 begin
3 if Clk'EVENT and Clk = '1' then
4 --decalage de la donnée de deux fronts montant
5 decalage_data_in_1 <= User_Data_in ;
6 decalage_data_in_2 <= decalage_data_in_1;

```

```

7
8 Addr <= User_Address; -- recopier l'adresse d'entrée du controller en entrée de la SRAM
9 end if;
10 end process;
11
12 process(Clk)
13 begin
14 if Clk'EVENT and Clk = '0' then -- sur front descendant
15 Data_in_s <= "0000" & decalage_data_in_2; --Ajout des 4 bits de parités dans à la donnée
16 User_Data_out <= Data_out_s(31 downto 0); --Renvoie des 32 bits sur la sortie
17 end if;
18 end process;

```

---

### 1.3.3 Test bench

Le test bench de notre composant SRAM complet se résume à tester plusieurs points:

- Que les instructions de lecture/ecriture données par l'utilisateur sont bien traitées par la FSM.
- Les données à écrire/lire sont bien traitées par l'IO Buffer.
- Les données sont correctement transmises à la SRAM.

Pour ce faire, nous allons d'abord exécuter une séquence d'écriture/lecture à l'adresse 0. Ensuite, nous ferons la même chose à l'adresse 7FFF... (soit la dernière adresse de la SRAM). Et enfin pour vérifier que la SRAM stock bien les données, nous vérifions que la donnée à l'adresse 0 est toujours présente.

Ces tests nous permettront de nous assurer du bon fonctionnement de notre implémentation du Contrôleur SRAM.

Le test bench est disponible sur GitHub sous le nom de fichier `tb_sram_controller.vhd`.

Voici sur la page suivante, la simulation du test bench:

La configuration de la simulation est disponible dans le répertoire GitHub sur le nom de `tb_sram_controller_behav.wcfg`.



Figure 1.7: Simulation Test Bench Contrôleur SRAM

Des marqueurs ont été placés pour indiquer les lectures aux différentes adresses. On constate que les données lues sont bien celles qui ont été écrites précédemment. à la lecture, le bus DQ de la SRAM est mis en haute impédance, ce qui est visible sur la simulation.

Les données et les adresses sont bien décalées d'un cycle d'horloge, comme prévu.

Ainsi, nous avons validé le bon fonctionnement de notre Contrôleur SRAM.

## 1.4 Mode Burst

La SRAM est capable de fonctionner en mode Burst. Ce mode permet de lire ou d'écrire plusieurs mots consécutifs en une seule opération, ce qui améliore les performances lors de l'accès à des blocs de données.

Nous allons implémenter ce mode dans notre contrôleur SRAM pour optimiser les opérations de lecture et d'écriture.

### 1.4.1 Implémentation du mode Burst

Premièrement, le signal **ADV/LV#0** varira en fonction du mode de fonctionnement.

Pour l'instant, il est à l'état de constante à 0.

Nous allons donc assigner cette variable à 0 dans notre FSM à l'état **IDLE**, **READ** et **WRITE**.

Après cette étape, un rapide lancement de la simulation du Contrôleur SRAM indique que ce changement n'a rien cassé.

#### FSM

Pour l'implémentation du mode Burst, nous allons ajouter deux nouveaux états à notre FSM existante : **READ\_BURST** et **WRITE\_BURST**.

Ces états géreront les opérations de lecture et d'écriture en mode Burst.

De plus il faut désormais gérer des signaux que nous avions laissé de côté précédemment

:

- **Ld\_n**, permet d'autoriser ou de bloquer le changement d'adresse lors d'une opération en cours.
- **CE\_n**, nécessaire à 0 si **Ld\_n** est à 0 pour que l'adresse soit prise en compte.
- **OE\_n**,

Voici un extrait de la FSM avec la gestion de ces signaux:

```
1 process(state)
2     begin
3         case state is
4             When INIT =>
5                 ...
6             when IDLE =>
7                 Rw_n <= '1'; --protection materiel
8                 CE_n    <= '1';
9                 OE_n    <= '1';
10                Ld_n    <= '1';
11                T_s     <= '0';
12
13            when READ =>
14                Rw_n <= '1'; -- on assignera cette valeur au trigg de la SRAM par la suite
15                T_s    <='1';
16                CE_n    <= '0';
17                OE_n    <= '0';
18                Ld_n    <= '0'; -- BEGIN
19                --Addr   <= User_Address;
20
21            when WRITE =>
22                Rw_n <= '0';
23                T_s    <='0';
24                CE_n    <= '0';
25                OE_n    <= '1';
26                Ld_n    <= '0'; -- BEGIN
27                --Addr   <= User_Address;
28
29            when READ_BURST =>
30                ...
31            when WRITE_BURST =>
32                ...
33        end case;
34    end process;
```

En ajoutant la gestion de ces signaux, Il faut s'assurer que le mode de fonctionnement hors Burst reste intact.

Nous allons donc relancer une simulation pour vérifier que tout fonctionne correctement. Le test bench à d'ailleur été amélioré pour afficher la dernière lecture de données sur l'adresse 0.



Figure 1.8: Simulation après ajout des signaux CE\_n, OE\_n et Ld\_n

La logique de changement d'état de la FSM doit également être mise à jour pour inclure les nouveaux états de Burst.

Voici un extrait de la logique de changement d'état mise à jour :

```

1
2 process(Clk,reset)
3 begin
4     if reset = '1' then
5         state <= INIT;
6
7     elsif Clk'EVENT and Clk = '1' then
8         case state is
9             When INIT =>
10                 state <= IDLE;
11
12             when IDLE =>
13                 if Ctrl ='1' AND Start ='1' AND Burst ='0' then
14                     state <= READ;
15                 elsif Ctrl ='0' AND Start ='1' AND Burst ='0' then
16                     state <= WRITE;
17                 else
18                     state <= IDLE;
19                 end if;
20
21             when READ =>
22                 if Burst = '1' AND Start = '1' then
23                     state <= READ_BURST;
24                 elsif Ctrl = '1' AND Start = '1' then
25                     state <= READ;
26                 elsif Ctrl = '0' AND Start = '1' then
27                     state <= WRITE;
28                 else
29                     state <= IDLE;
30                 end if;
31
32             when WRITE =>
33                 if Burst = '1' AND Start = '1' then
34                     state <= WRITE_BURST;
35                 elsif Ctrl = '1' AND Start = '1' then
36                     state <= READ;
37                 elsif Ctrl = '0' AND Start = '1' then
38                     state <= WRITE;
39                 else
40                     state <= IDLE;
41                 end if;
42
43             when READ_BURST =>
44                 if Ctrl ='1' AND Start='1' AND Burst ='0' then
45                     state <= READ;
46                 elsif Ctrl ='0' AND Start='1' AND Burst ='0' then
47                     state <= WRITE;
48                 elsif Burst ='1' AND Start='1' then
49                     state <= READ_BURST;
50                 else

```

```

51           state <= IDLE;
52       end if;

53
54       when WRITE_BURST =>
55           if Ctrl ='1' AND Start='1' AND Burst ='0' then
56               state <= READ;
57           elsif Ctrl ='0' AND Start='1' AND Burst ='0' then
58               state <= WRITE;
59           elsif Burst ='1' AND Start='1' then
60               state <= WRITE_BURST;
61           else
62               state <= IDLE;
63           end if;

64
65       end case;
66   end if;
67 end process;
68

```

DQ est passé en bidirectionnel inout ce n'était pas le cas avant nous utilisionss un signal qui décalait la donnée pour la mettre en sortie ou en entrée.

Nous avons été contraint d'ajouter un signal intermédiaire T\_s\_reg qui gère la direction du bus de données bidirectionnel.

Si la direction du bus change instantanément sans passer par un registre, nous risquons un conflit de bus : le FPGA et la SRAM essaient de parler en même temps sur le même fil pendant une fraction de seconde, ce qui crée des courts-circuits en simulation.

T\_s\_reg permet de s'assurer que l'ordre de passer en haute impédance est parfaitement aligné avec le cycle d'horloge où la donnée doit sortir.

Nopus avons également ajouté un registre pour l'adresse de burst : burst\_addr.  
Il faut séparer clairement adresse de départ et adresse courante du burst.

Il faut incrementer la donnée sur le write burst pour voir si tout va bien.  
Une simple boucle dans le test bench permet de faire cela.

Il y'a eu une confusion avec le signal Ld\_n.

Nous avons forcé l'incrementation de l'adresse par le Contrôleur durant le mode burst.  
Or, la SRAM est capable de gérer l'incrementation automatique de l'adresse en mode burst si Ld\_n est à 1.

Si nous voulons faire un programme plus preformant, il faudrait reprendre le code et changer l'incrementation forcée par celle de la sram.

Par souci de temps, nous laisserons cela ainsi pour le moment. Cela est amplement suffisant pour valider le fonctionnement du Contrôleur.

Voici la partie du test bench pour le mode burst:

Nous avons fait le choix d'ajouter cette partie au test bench existant plutot que de créer un nouveau test bench dédié au mode burst.

```

2      wait for 1*(TCLKH+TCLKL);
3      Data_in_s <= "00000000000000000000000000000001"; -- 32 bits
4
5      wait for 1.25*(TCLKH+TCLKL);
6      Addr_in_s <= "00000000000000000000000000000001"; -- 19 bits
7      wait for 1.25*(TCLKH+TCLKL); --write
8          user_Burst <='0';
9          user_Ctrl <= '0';
10         R_W_enable <='1';
11         --nRW_s     <= '0';
12
13     wait for 1.25*(TCLKH+TCLKL); --write BURST
14         user_Burst <='1';
15         -- Boucle d'incrémentation manuelle synchronisée sur l'horloge
16     for i in 0 to 4 loop
17         wait until rising_edge(CLKO_SRAM);
18         Data_in_s <= std_logic_vector(unsigned(Data_in_s) + 1);
19     end loop;
20
21     wait for 8.75*(TCLKH+TCLKL);--read
22     user_Burst <='0';
23     --wait for 1.25*(TCLKH+TCLKL);
24     Addr_in_s <= "00000000000000000000000000000001"; -- 19 bits on va relire les données écrit avec le burst
25     user_Ctrl <= '1';
26     R_W_enable <='1';
27     --nRW_s     <= '1';
28
29     wait for 2.5*(TCLKH+TCLKL);--read BURST
30     user_Burst <='1';
31     user_Ctrl <= '1';
32     R_W_enable <='1';
33     --nRW_s     <= '1';

```

---

L'écriture en mode burst fonctionne parfaitement, de même pour la lecture.  
nous incrémentation la donnée à chaque cycle d'horloge pendant le burst pour vérifier que tout fonctionne correctement.



Figure 1.9: Simulation write mode burst

Ensuite nous lisons les données en mode burst en reprenant les mêmes address que pour l'écriture.



Figure 1.10: Simulation read mode burst

Le fait qu'on ait utilisé un compteur forcé au lieu du Ld\_n permet de ecrire/lire plus

de 4 données à la suite car on est limité avec le compteur de la sram.

à partir de là, nous pouvons considérer que le mode burst est fonctionnel.

Il reste cependant quelques améliorations à apporter pour rendre le contrôleur plus robuste et efficace.

Par exemple, l'utilisation de l'incrementation automatique de l'adresse par la SRAM elle-même en mode burst, plutôt que de gérer cela manuellement dans le contrôleur.

Cela nécessiterait une révision de la gestion du signal Ld\_n et une adaptation de la logique de la FSM pour s'aligner avec le comportement de la SRAM en mode burst.

## 1.5 Estimation de la durée d'exécution du contrôleur SRAM

L'estimation de la durée d'exécution du contrôleur SRAM a été réalisée à partir des chronogrammes issus des simulations ModelSim présentées dans ce compte rendu. Ces simulations permettent d'observer précisément l'évolution des signaux en fonction du temps et des cycles d'horloge, et constituent donc une base fiable pour une estimation temporelle du fonctionnement du contrôleur.

Le contrôleur SRAM est entièrement synchronisé sur l'horloge Clk. Chaque transition d'état de la machine à états finis ainsi que chaque opération de lecture ou d'écriture s'effectue sur des fronts d'horloge bien définis. La durée d'exécution d'une opération dépend donc directement du nombre de cycles d'horloge nécessaires à son déroulement.

### 1.5.1 Accès en mode lecture et écriture simple

D'après les chronogrammes de simulation, une opération d'écriture simple se déroule selon les étapes suivantes :

- Un cycle pour la prise en compte de la commande et de l'adresse utilisateur.
- Un cycles de décalage de la donnée afin de respecter les contraintes temporelles de la SRAM.
- un cycle effectif d'écriture dans la mémoire.

On observe ainsi qu'une écriture simple nécessite environ 3 cycles d'horloge entre la demande utilisateur et la fin effective de l'opération.

De manière similaire, une opération de lecture simple comprend :

- Un cycle pour la validation de la commande et de l'adresse.
- Un cycle pour l'accès mémoire.
- Un cycle pour la récupération et la stabilisation de la donnée en sortie.

La durée d'une lecture simple est donc également de l'ordre de 3 cycles d'horloge, comme confirmé par les marqueurs visibles sur les chronogrammes de simulation.

### 1.5.2 Accès en mode Burst

En mode Burst, l'estimation est plus favorable. Les captures de simulation montrent que:

Le premier accès du burst présente un coût similaire à une lecture ou écriture simple. Les accès suivants sont réalisés à raison d'un mot par cycle d'horloge. Ainsi, pour un burst de N mots, la durée totale peut être estimée à: Un coût initial de quelques cycles (initialisation du burst), puis N cycles supplémentaires pour les N transferts consécutifs. Les chronogrammes de simulation en mode Burst confirment ce comportement, avec une incrémentation de la donnée et une lecture/écriture valide à chaque cycle d'horloge pendant la phase de burst.

### 1.5.3 Limites de l'estimation

Cette estimation repose sur un modèle simulé et ne prend pas en compte les délais physiques liés au FPGA, les temps de propagation réels, ni les éventuelles contraintes liées à l'implémentation matérielle finale.

Cependant, dans le cadre de ce projet, l'analyse temporelle basée sur les captures de simulation est suffisante pour caractériser le comportement du contrôleur SRAM et comparer les performances entre les modes simple et burst.

## 1.6 Conclusion

Ce projet avait pour objectif de concevoir et implémenter en VHDL un contrôleur de mémoire SRAM en respectant les contraintes temporelles et fonctionnelles du composant mt55l512y36f.

Dans un premier temps, l'étude et la validation de l'IO Buffer ont permis de comprendre le fonctionnement du bus bidirectionnel et de garantir une gestion correcte des phases de lecture et d'écriture, notamment grâce à la mise en haute impédance du bus lors des lectures.

La conception du contrôleur SRAM s'est appuyée sur une machine à états finis assurant une gestion fiable des accès mémoire. Les décalages d'horloge entre données, adresses et signaux de contrôle ont été correctement pris en compte à l'aide de registres synchronisés, ce qui a permis de respecter les exigences de la SRAM. Les simulations réalisées à l'aide des test bench ont validé le bon fonctionnement des opérations de lecture et d'écriture sur l'ensemble de l'espace mémoire.

L'implémentation du mode Burst a permis d'améliorer les performances du contrôleur en autorisant des accès consécutifs à la mémoire. Bien que l'incrémentation de l'adresse ait été gérée manuellement par le contrôleur pour des raisons de temps, les simulations montrent que le mode Burst fonctionne correctement en lecture comme en écriture.

Ce projet a ainsi permis de mettre en pratique la conception d'un système matériel complet en VHDL, depuis l'analyse du composant jusqu'à la validation par simulation. Des améliorations restent possibles, notamment en exploitant pleinement les mécanismes internes de la SRAM pour optimiser le mode Burst, mais le contrôleur développé répond

aux objectifs fixés et constitue une base solide pour des évolutions futures.