

## Laboratoire n°2

# Conception d'un microprocesseur

Professeur:

**Yvon Savaria**

[yvon.savaria@polymtl.ca](mailto:yvon.savaria@polymtl.ca)

Inspiré du travail de:

**Mickaël Fiorentino**

[mickael.fiorentino@polymtl.ca](mailto:mickael.fiorentino@polymtl.ca)

Chargé de laboratoire:

**Justin Pabot**

[justin.pabot@polymtl.ca](mailto:justin.pabot@polymtl.ca)

Chargé de laboratoire:

**Timothée TREMBLY**

[timothee-mateo.trembly@polymtl.ca](mailto:timothee-mateo.trembly@polymtl.ca)

Automne 2023

---

## TABLE DES MATIÈRES

|                                        |          |
|----------------------------------------|----------|
| <b>1 Introduction</b>                  | <b>2</b> |
| 1.1 Objectifs du laboratoire . . . . . | 2        |
| 1.2 Dossier de travail . . . . .       | 3        |
| 1.3 Barème de notation . . . . .       | 4        |
| 1.4 Pénalités de retard . . . . .      | 4        |
| 1.5 Rapport . . . . .                  | 4        |
| <b>2 Directives</b>                    | <b>5</b> |
| 2.1 Modules . . . . .                  | 5        |
| 2.2 Core . . . . .                     | 5        |
| 2.3 Implémentation . . . . .           | 5        |
| 2.4 Performances - Bonus . . . . .     | 6        |

# 1 INTRODUCTION

La complexité d'un circuit numérique intégré à très grande échelle, tel qu'un microprocesseur, serait impossible à gérer avec les outils de conception de bas niveau (dessin des masques) que nous avons utilisé dans le laboratoire n°1. Pour mieux gérer la complexité des circuits intégrés, tout en gardant les coûts de développement dans des limites raisonnables, les outils de synthèses associés aux langages de description architecturale comme le VHDL ou le Verilog, ainsi que les outils de placement et routage automatisés permettent de générer le dessin des masques d'un circuit à partir de sa description comportementale de haut niveau.

## 1.1 OBJECTIFS DU LABORATOIRE

Ce deuxième laboratoire consiste à concevoir un microprocesseur. Il a pour objectif de vous familiariser avec la conception, la simulation, la synthèse, et l'implémentation physique de systèmes numériques complexes à l'aide d'outils de conception automatisés. Vous passerez ainsi à travers le flot de conception standard, tel que schématisé à la FIGURE 1. En particulier, ce laboratoire vous permettra de :

- Concevoir un modèle de processeur avec le langage VHDL.
- Réaliser des simulations comportementales (modèle VHDL), et temporelles (*netlist* post-synthèse et post-implémentation) du processeur.
- Réaliser la synthèse logique du processeur en utilisant la technologie en 45 nm du kit GPDK045 .
- Réaliser les placement & routage automatisés à partir de la *netlist* post-synthèse du processeur.

De plus, les points suivants ne sont pas exigibles, mais restent à notre sens intéressants à étudier si le temps vous le permet :

- Inclure les structures de testabilité (*Design For Test* (DFT)) au processeur et générer des vecteurs de tests.
- Évaluer la consommation d'énergie du processeur à partir de ses informations post-implémentation et de l'activité qu'il a générée en simulation temporelle.

La documentation du processeur contient toutes les informations nécessaires à sa conception. En vous aidant des fichiers initialement fournis et de la documentation, vous concevrez d'abord chacun des modules composant le processeur. Vous utiliserez alors ces modules pour concevoir le *core* pipeliné du processeur. Le langage VHDL sera présenté en classe.

Une fois le processeur modélisé au niveau comportemental, vous suivrez le [tutoriel numérique](#), qui vous guidera dans l'apprentissage des techniques de simulation, de synthèse, de testabilité, de placement & routage, et d'évaluation de la consommation d'énergie avec les outils *Modelsim*, *Genus*, *Modus*, *Innovus* et *Voltus* à travers l'exemple d'un compteur BCD. Le modèle VHDL de ce dernier vous est également fourni si vous souhaitez vous pratiquer sur un cas simple avant de vous attaquer au processeur.



FIGURE 1 – Flot de conception

## 1.2 DOSSIER DE TRAVAIL

Le dossier de travail associé au laboratoire n°2 est disponible sur un répertoire *git*. Téléchargez ce répertoire sur votre station de travail avant de commencer :

---

```
% cd ~/Labs
% git clone https://git.step.polymtl.ca/ele8304/lab2.git
```

---

Le dossier de travail est organisé de la façon suivante :

---

```
asm/..... # Programmes assembleur
scripts/..... # Automatisation du flot de conception
sources/..... # Code source VHDL
constraints/..... # Fichiers de contraintes
simulations/..... # Simulations comportementales et temporelles
implementation/..... # Synthèse logique, placement et routage
doc/..... # Documentation, Rapport
```

---

### 1.3 BARÈME DE NOTATION

TABLEAU 1 – Barème de notation

|                             |           |
|-----------------------------|-----------|
| <b>Modules</b>              | <b>/5</b> |
| <b>Core</b>                 | <b>/9</b> |
| <b>Implémentation</b>       | <b>/4</b> |
| <b>Qualité du rapport</b>   | <b>/2</b> |
| <b>Performances (bonus)</b> | <b>/2</b> |

Le TABLEAU 1 donne la répartition des points du laboratoire. 14 points sont alloués à la conception et à la simulation des modules et du *core* en VHDL. 4 points sont alloués au flot de conception (synthèse, testabilité, placement & routage, vérifications). 2 points sont alloués à la qualité du rapport. Enfin, **2 points bonus** sont alloués à l'évaluation des performances et de la consommation d'énergie du processeur.

### 1.4 PÉNALITÉS DE RETARD

La date limite de remise du laboratoire est précisée sur Moodle. Les pénalités de retard  $P_{retard}$  sont calculées en fonction du nombre  $h$  d'heures de retard tel que :

$$P_{retard} = 0.5 \times \left[ 1 + \left( \frac{h}{24} \right)^2 \right]$$

### 1.5 RAPPORT

Votre rapport doit inclure tous les éléments nécessaires à la justification de vos analyses. C'est-à-dire vos résultats de simulation, vos résultats de synthèse et d'implémentation, et tout autre élément que vous jugerez pertinent pour démontrer votre bonne compréhension du travail réalisé. Les 2 points alloués à la qualité du rapport concernent la précision du vocabulaire employé, la qualité de la présentation et des figures, ainsi que la qualité de la syntaxe et de l'orthographe. Une seule remise par groupe est nécessaire. On vous demande de remettre un fichier compressé (.zip) sur Moodle avant l'échéance de remise du laboratoire contenant le dossier de travail complété de votre travail, en particulier :

- Votre rapport au format PDF.
- Vos codes sources VHDL (modules, *core*, et bancs d'essais).
- Vos scripts *tcl* pour la simulation, la synthèse, et l'implémentation.
- Vos résultats post-synthèse et post-implémentation (*netlist*, rapports de STA, DRC, LVS, rapports d'énergie, surface occupée etc.)

**Remarque**—Nous souhaitons avoir vos commentaires sur les difficultés que vous avez rencontrées ainsi que le temps d'apprentissage que vous avez passé sur les outils durant la réalisation de ce laboratoire. Nous sommes particulièrement intéressés aux lacunes pouvant subsister dans la documentation.

## 2 DIRECTIVES

### 2.1 MODULES

Dans cette première partie, on vous demande de concevoir les modules composant le processeur. Les explications relatives au fonctionnement des modules, leurs schémas de principe, et leurs interfaces VHDL, sont détaillés dans la documentation du processeur. En particulier, on vous demande de :

- Comprendre et concevoir le modèle VHDL de tous les modules décrit dans la documentation du processeur, en respectant avec *exactitude* leurs interfaces VHDL, et de valider leur fonctionnement à l'aide d'une simulation comportementale et d'un banc d'essai. **(5 pts)**

Afin d'accélérer votre avancée, certains modules vous sont déjà fournis, en particulier :

- Le banc de registres
- Le *Program Counter*
- L'Unité Arithmétique et Logique (ALU)

**Il vous reste donc à créer le modèle VHDL de l'adder 32 bits, ainsi que les bancs d'essais des 4 modules.**

### 2.2 CORE

Dans cette partie, nous vous demandons de concevoir le *core* du processeur en utilisant les modules réalisés précédemment. Le fonctionnement du *pipeline* est détaillé dans la documentation. En particulier, on vous demande de :

- Concevoir le modèle VHDL du *core* tel que décrit dans la documentation, en respectant avec *exactitude* son interface VHDL. **(6 pts)**
- Valider son fonctionnement à l'aide d'une simulation comportementale et d'un banc d'essai montrant l'exécution du benchmark **riscv\_basic.S** fourni dans le dossier de travail. **(3 pts)**

Pour pouvoir exécuter un programme avec votre processeur, nous vous fournissons également un banc d'essai. Notez que celui-ci instancie la mémoire double port (`dpm.vhd`) fournie dans le dossier de travail. Il est également possible d'effectuer des tests complémentaires avec vos propres programmes assembleurs en utilisant le Makefile pour la compilation. Assurez-vous que le fichier d'initialisation de la mémoire d'instruction (`*.hex`) reflète les modifications que vous avez apportées à votre programme après la compilation.

### 2.3 IMPLÉMENTATION

Dans cette partie on vous demande de réaliser l'implémentation physique du processeur en utilisant la technologie 45 nm du kit GPDK045 de Cadence. En particulier, on vous demande de :

- Réaliser la synthèse logique du processeur, **sans inclure la testabilité**. Celle-ci peut également être réalisée si le temps vous le permet, et sera un motif de bonification. Vérifiez que les contraintes temporelles sont respectées avec l'outil STA, et validez le fonctionnement du processeur à l'aide

d'une simulation temporelle post-synthèse. Utilisez le même banc d'essai que pour la simulation comportementale, et mettez en évidence les délais dans le circuit. **(2 pts)**

- Réaliser le placement & routage du processeur. Vérifiez que les contraintes temporelles sont respectées avec l'outil STA, vérifiez l'intégrité de son dessin des masques avec les vérifications DRC et LVS, et validez le fonctionnement du processeur à l'aide d'une simulation temporelle post-placement-routage (même banc d'essai). **(2 pts)**

## 2.4 PERFORMANCES - BONUS

Dans cette partie on vous demande d'évaluer les performances de votre processeur post-implémentation. C'est à dire, de mettre en parallèle le temps d'exécution du *benchmark riscv\_basic.S* avec l'énergie consommée pendant son exécution. En particulier, on vous demande de :

- Réaliser la simulation post-implémentation du processeur en exécutant le *benchmark riscv\_basic.S*. Utilisez le même banc d'essai que pour la simulation comportementale. Enregistrez l'activité générée par la simulation temporelle dans un fichier `vcd`.
- Déterminer la performance de votre processeur en Million d'Instructions Par Secondes (*MIPS*), en utilisant les informations fournies par votre compteur de performance.
- Évaluer la puissance moyenne  $P$  (en mW) consommée par votre processeur pendant l'exécution du programme à partir de l'activité enregistrée en simulation post-implémentation. Le ratio  $MIPS/P$  sera la métrique de référence.

**N.B. : Notez qu'il est possible d'effectuer des modifications de dimensionnement (incluant des modifications du circuit et du flux de conception) de façon à obtenir les meilleures performances possibles. Si vous faites ce choix, vérifiez le respect des contraintes temporelles avec l'outil STA.**

Le nombre de points accordés pour une partie/la totalité des démarches présentées ci-dessus sera laissée à l'appréciation des chargés de laboratoire, selon le soin qui leur est apporté et l'avancement moyen de chaque équipe.