# TP4 : Conception d'une architecture PC/PO : circuit PGCD sur FPGA

**Préparation :** Relire et comprendre le TD 6 et lire entièrement l'énoncé de ce TP avant la séance.

Le but de ce TP est d'implanter le circuit PGCD vu en TD et de le faire fonctionner sur la carte FPGA. On rappelle l'algorithme utilisé :

```
procedure PGCD is
   A, B: Positive; -- A et B sont codés sur 8 bits
begin
   Get(A); Get(B);
   while A /= B loop
   if A < B then
      B := B - A;
   else
      A := A - B;
   end if;
   end loop;
   Put(B);
end;</pre>
```

Récupérer l'archive du TP sur Chamillo et la décompresser à l'endroit de votre choix.

## Ex. 1 : Partie opérative

Le fichier vhd/P0.vhd contient un squelette de la partie opérative du circuit. Pour le compléter, vous aurez besoin des composants fournis suivants :

- FD8CE : un registre 8 bits avec une entrée d'activation synchrone et une entrée de remise à zéro asynchrone,
- COMPM8: un comparateur d'entiers sur 8 bits,
- ADSU8: un additionneur / soustracteur sur 8 bits.

La documentation des composants COMPM8 et ADSU8 est donnée en annexe.

Question 1 Dessiner le schéma de la partie opérative du circuit avec les composants ci-dessus et en utilisant les noms de signaux de vhd/PO.vhd.

Question 2 Compléter le fichier vhd/PO.vhd. Vous aurez besoin des informations suivantes :

- Pour construire un multiplexeur en VHDL, on peut utiliser l'affectation concurrente conditionnelle. Par exemple, S <= E1 when C = '1' else E0, permet de décrire un multiplexeur à 2 entrées de données E0 et E1, commandé par l'entrée de contrôle C. La sortie S doit être du même type que les entrées de données.
- En VHDL, les valeurs logiques doivent être mises entre apostrophes ('0', '1').
- Lors d'un port map, si certaines sorties ne sont pas utilisées, on pourra les connecter à open.

Question 3 Lancer la simulation sur le banc d'essai  $vhd/tb_P0.vhd$  en utilisant la commande :  $make run_simu TOP=P0$ 

Ajouter les signaux permettant d'observer les valeurs des deux registres. Pensez à organiser les signaux de façon la plus lisible possible (séparateurs, couleurs, radix, etc.) commme cela a été vu au TP 3.

La simulation doit se terminer par le message *Simulation terminée*. Si des messages d'erreurs apparaissent dans le simulateur, corriger la PO.

#### Ex. 2 : Partie contrôle

On doit maintenant implanter la partie contrôle du circuit PGCD. Pour cela, on peut choisir de décrire l'automate en codage implicite comme vu dans le TP précédent.

L'avantage de cette description, est de confier au compilateur les optimisations tout en déduisant la description directement à partir du graphe de l'automate.

On rappelle l'automate de la partie contrôle du circuit.



Question 1 Compléter le fichier vhd/PC.vhd pour y implanter l'automate en utilisant un codage implicite (cf. TP précédent).

## Ex. 3: Simulation du bloc PC/PO

Le fichier vhd/pgcd.vhd fourni instancie les parties PO et PC déjà réalisées. Ce fichier peut être testé grâce au fichier vhd/tb\_pgcd.vhd et à la commande :

\$ make run simu TOP=PGCD

Question 1 Lancer la simulation en l'organisant de manière lisible (radix, séparateur, couleur). Quelles sont les valeurs d'entrées utilisées pour les ports A0 et B0? Vérifier que la valeur fournie par votre circuit correspond bien au PGCD de ces valeurs. Donner le nombre de cycles d'horloge nécessaire pour obtenir ce PGCD avec votre circuit.

Ajouter à votre chronogramme, les signaux du registre d'état (les signaux q\_i dans iPC) et des registres de données de la PO. Vérifier cycle par cycle le bon fonctionnement de votre circuit.

## Ex. 4: Implantation sur le FPGA

On va implanter le circuit PGCD sur la carte FPGA, en utilisant les interrupteurs pour entrer les valeurs des paramètres et les LEDS pour afficher le résultat.

Question 1 Donner le schéma correspondant au fichier vhd/pgcdfpga.vhd.

Sachant que la carte ne dispose que de 4 interrupteurs, 4 boutons poussoirs et 4 LEDs, expliquer l'intérêt de ce circuit. Retrouver notamment les boutons qui permettent de manipuler les premiers bits de B et celui qui opère l'affichage des bits de poids faibles ou forts.

Question 2 Après avoir branché la carte correctement, implorer la puissance du FPGA par la commande :

\$ make run\_fpga TOP=PGCDFPGA

Vérifier sur carte le bon fonctionnement de votre circuit.

#### ADSU8

Macro: 8-Bit Cascadable Adder/Subtracter with Carry-In, Carry-Out, and Overflow



#### Introduction

When the ADD input is High, this element adds two 8-bit words (A7:A0 and B7:B0) and a carry-in (CI), producing, an 8-bit sum output (S7:S0) and carry-out (CO) or an overflow (OFL).

When the ADD input is Low, this element subtracts B7:B0 from A7:A0, producing an 8-bit difference output (S7:S0) and a carry-out (CO) or an overflow (OFL).

In add mode, CO and CI are active-High. In subtract mode, CO and CI are active-Low. OFL is active-High in add and subtract modes.

## Logic Table

|                                      | Output |    |           |  |
|--------------------------------------|--------|----|-----------|--|
| ADO                                  |        |    | 5         |  |
| 1                                    | An     | Bn | An+Bn+CI* |  |
| 0                                    | An     | Bn | An-Bn-CI* |  |
| CI*: ADD = 0, CI<br>CI*: ADD = 1, CI |        |    |           |  |

**Unsigned Binary Versus Two's Complement -**This design element can operate on either 8-bit unsigned binary numbers or 8-bit two's-complement numbers. If the inputs are interpreted as unsigned binary, the result can be interpreted as unsigned binary. If the inputs are interpreted as two's complement, the output can be interpreted as two's complement. The only functional difference between an unsigned binary operation and a two's-complement operation is the way they determine when "overflow" occurs. Unsigned binary uses CO, while two's complement uses OFL to determine when "overflow" occurs.

With adder/subtracters, either unsigned binary or two's-complement operations cause an overflow. If the result crosses the overflow boundary, an overflow is generated. Similarly, when the result crosses the carry-out boundary, a carry-out is generated.

**Unsigned Binary Operation -**For unsigned binary operation, this element can represent numbers between 0 and 255, inclusive. In add mode, CO is active

(High) when the sum exceeds the bounds of the adder/subtracter. In subtract mode, CO is an active-Low borrow-out and goes Low when the difference exceeds the bounds.

An unsigned binary "overflow" that is always active-High can be generated by gating the ADD signal and CO as follows:

unsigned overflow = CO XOR ADD

OFL is ignored in unsigned binary operation.

**Two's-Complement Operation -**For two's-complement operation, this element can represent numbers between -128 and +127, inclusive. If an addition or subtraction operation result exceeds this range, the OFL output goes High. CO is ignored in two's-complement operation.

## **Design Entry Method**

This design element is only for use in schematics.

#### For More Information

- See the *Spartan-3 Generation FPGA User Guide*.
- See the Spartan-3 FPGA Family Data Sheet.

#### COMPM8

Macro: 8-Bit Magnitude Comparator



#### Introduction

This design element is an 8-bit magnitude comparator that compare two positive Binary-weighted words. It compares A7: A0 and B7: B0, where A7 and B7 are the most significant bits.

The greater-than output (GT) is High when A > B, and the less-than output (LT) is High when A < B When the two words are equal, both GT and LT are Low. Equality can be measured with this macro by comparing both outputs with a NOR gate.

## **Logic Table**

| Deputs.                                                                                                        |                                                                                                      |                                                                                            |                                                                                  |                                                                        |                                                              |                                                    | Outputs |      |    |
|----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------|---------|------|----|
| A7, 87                                                                                                         | AG, DS                                                                                               | A5, B5                                                                                     | A4, D4                                                                           | A5, 83                                                                 | A2, B2                                                       | A1, D1                                             | AO, BO  | gT . | LT |
| A7>B7                                                                                                          | X                                                                                                    | X                                                                                          | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 1    | 0  |
| A7 <b7< td=""><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>0</td><td>1</td></b7<> | X                                                                                                    | X                                                                                          | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6>B6                                                                                                | X                                                                                          | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 1    | 0  |
| A7=B7                                                                                                          | A6 <b6< td=""><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>0</td><td>1</td></b6<> | X                                                                                          | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5>B5                                                                                      | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 1    | 0  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5 <b5< td=""><td>X</td><td>X</td><td>X</td><td>X</td><td>X</td><td>0</td><td>1</td></b5<> | X                                                                                | X                                                                      | X                                                            | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4>B4                                                                            | X                                                                      | X                                                            | X                                                  | X       | 1    | 0  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4 <b4< td=""><td>X</td><td>X</td><td>X</td><td>X</td><td>0</td><td>1</td></b4<> | X                                                                      | X                                                            | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3>B3                                                                  | X                                                            | X                                                  | X       | 1    | 0  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3 <b3< td=""><td>X</td><td>X</td><td>X</td><td>0</td><td>1</td></b3<> | X                                                            | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3=B3                                                                  | A2>B2                                                        | X                                                  | X       | 1    | 0  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3=B3                                                                  | A2 <b2< td=""><td>X</td><td>X</td><td>0</td><td>1</td></b2<> | X                                                  | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3=B3                                                                  | A2=B2                                                        | A1>B1                                              | X       | 1    | 0  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3=B3                                                                  | A2=B2                                                        | A1 <b1< td=""><td>X</td><td>0</td><td>1</td></b1<> | X       | 0    | 1  |
| A7=B7                                                                                                          | A6=B6                                                                                                | A5=B5                                                                                      | A4=B4                                                                            | A3=B3                                                                  | A2=B2                                                        | A1=B1                                              | A0>B0   | 1    | 0  |

| hayan. |        |        |        |        |        | Outputs |                                          |    |    |
|--------|--------|--------|--------|--------|--------|---------|------------------------------------------|----|----|
| A7, 87 | AG, 36 | A5, B5 | A4, B4 | A3, B3 | A2, B2 | A1, B1  | AG, BG                                   | GT | LT |
| A7=B7  | A6=B6  | A5=B5  | A4=B4  | A3=B3  | A2=B2  | A1=B1   | A0 <b0< td=""><td>0</td><td>1</td></b0<> | 0  | 1  |
| A7=B7  | A6=B6  | A5=B5  | A4=B4  | A3=B3  | A2=B2  | A1=B1   | A0=B0                                    | 0  | 0  |

# **Design Entry Method**

This design element is only for use in schematics.

# **For More Information**

- See the <u>Spartan-3 Generation FPGA User Guide</u>.
- See the Spartan-3 FPGA Family Data Sheet.