# TP2 EN 1B CHRONOMETRE 2021-2022

**Oliver BELLIARD & Fahd RAFIK** 

BELLIARD & RAFIK 1/6

La préparation se trouve en annexe.



Simulation Cmpt0to3.

Le chronogramme montre à la sortie N, en décimal, son incrémentation à chaque coup d'horloge. On peut aussi confirmer le bon fonctionnement du retour à 0. Nous avons donc bien un compteur qui compte de 0 à 3 seulement, à chaque front montant de l'horloge.



#### Schema Cmpt1to3 (RTL analysis)

Ce schéma montre l'opération réalisé par Vivado. Nous observons que le logiciel a bien reconnu l'opération qu'on réalisait et a remplacé les deux bascules D par un opérateur d'addition.

La séance s'est plutôt bien déroulée, nous n'avons pas rencontré de souci particulier en suivant les consignes du TP. A la fin du TP nous avons les afficheurs 7 segments qui essayent d'afficher 4 chiffres différents à la vitesse de l'horloge et qui affichent donc une valeur moyenne des 4 chiffres commandés avec les switchs.

Vous trouverez dans les annexes : la préparation, le schéma de Disp1of4Digit, son fichier de contraintes et le schéma de cmpt1to3 avec des LUT.

BELLIARD & RAFIK 2 / 6

#### Annexe 1:

### Préparation

BELLIARD & RAFIK 3 / 6



|                                           | Prepa 3.B    |            |                |        |  |
|-------------------------------------------|--------------|------------|----------------|--------|--|
|                                           | D(3)         | SW 15      | R <sub>2</sub> | Entrée |  |
|                                           | 1)(2)        | SW 24      | Tą             | ~      |  |
|                                           | 0(2)         | Sw 13      | Un             |        |  |
| 7                                         | D(0)         | SW12       | W2             |        |  |
|                                           | (13)         | SW11       | R <sub>3</sub> |        |  |
|                                           |              |            |                |        |  |
|                                           | C (2)        | SW 10      | Ta             | ~      |  |
|                                           | C (2)        | PW2        | T <sub>3</sub> |        |  |
|                                           | ( to)        | \$ \doldar | $\forall i$    |        |  |
|                                           | B(3)         | SW7        | W13            | ~      |  |
|                                           | B(2)         | SW6        | Woh            |        |  |
|                                           | B(2)         | 2W5        | V05            |        |  |
|                                           | B(0)         | 4.42       | W25            | 1      |  |
|                                           | A(3)         | 2w3        | W23            |        |  |
|                                           |              |            |                |        |  |
|                                           | A(2)         | 2 W S      | X26            |        |  |
|                                           | A(2)         | SWI        | V 26           | ~      |  |
|                                           | A(o)         | SWO        | V17            | N      |  |
|                                           | N (2)        | BINR       | T17            | ~      |  |
|                                           | Nto)         | BTND       | U17            |        |  |
|                                           | (216)        | CG         | U7             | Santie |  |
|                                           | 9(5)         | CF         | V5             |        |  |
|                                           | <b>5</b> (4) | CE         | U5             |        |  |
|                                           | \$(3)        | 60         | 18             | ~      |  |
|                                           |              |            |                | ~      |  |
|                                           | (8)          | CC         | 78             | 1      |  |
|                                           | \$(1)        | CB         | <b>W</b> 6     | ~      |  |
|                                           | \$(0)        | CA         | w7             | ~      |  |
| 10 10 10 10 10 10 10 10 10 10 10 10 10 1  | ENAN (3)     | AN3        | Wh.            |        |  |
| A 1 3 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 4 | ENAN(2)      | ANR        | VL             | N.     |  |
|                                           | (1)          | ANA        | UL             |        |  |
|                                           | ~ (6)        |            | U X            |        |  |
|                                           |              | 140        | V 1            |        |  |
|                                           |              |            |                |        |  |
|                                           |              |            |                |        |  |



#### Annexe 2:

#### Disp1of4Digit

BELLIARD & RAFIK 4 / 6



#### Annexe 3:

## Disp1of4Digit\_Basys3.xdc complété (Fichier de contraintes)

BELLIARD & RAFIK 5 / 6

```
# Basys3 Pin Assignments
# pour : Disp1of4Digit.vhd
        Disp4D.vhd
# version du 23/11/2021
####################################
# On-board Slide Switches #
# Connection: A(0) de Disp1of4Digit sur SW0 => V17
set_property PACKAGE_PIN V17 [get_ports {A[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {A[0]}]
# Connection: A(1) de Disp1of4Digit sur SW1 => V16
set_property PACKAGE_PIN V16 [get_ports {A[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {A[1]}]
# Connection: A(2) de Disp1of4Digit sur SW2 => W16
set_property PACKAGE_PIN W16 [get_ports {A[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {A[2]}]
# Connection: A(3) de Disp1of4Digit sur SW3 => W17
set_property PACKAGE_PIN W17 [get_ports {A[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {A[3]}]
# Connection: B(0) de Disp1of4Digit sur SW4 => W15
set_property PACKAGE_PIN W15 [get_ports {B[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {B[0]}]
# Connection: B(1) de Disp1of4Digit sur SW5 => V15
set_property PACKAGE_PIN V15 [get_ports {B[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {B[1]}]
# Connection: B(2) de Disp1of4Digit sur SW6 => W14
set_property PACKAGE_PIN W14 [get_ports {B[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {B[2]}]
# Connection: B(3) de Disp1of4Digit sur SW7 => W13
set_property PACKAGE_PIN W13 [get_ports {B[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {B[3]}]
# Connection: C(0) de Disp1of4Digit sur SW8 => V2
set_property PACKAGE_PIN V2 [get_ports {C[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {C[0]}]
# Connection: C(1) de Disp1of4Digit sur SW9 => T3
set_property PACKAGE_PIN T3 [get_ports {C[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {C[1]}]
# Connection: C(2) de Disp1of4Digit sur SW10 => T2
set_property PACKAGE_PIN T2 [get_ports {C[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {C[2]}]
# Connection: C(3) de Disp1of4Digit sur SW11 => R3
set_property PACKAGE_PIN R3 [get_ports {C[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {C[3]}]
# Connection: D(0) de Disp1of4Digit sur SW12 => W2
set_property PACKAGE_PIN W2 [get_ports {D[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {D[0]}]
# Connection: D(1) de Disp1of4Digit sur SW13 => U1
set_property PACKAGE_PIN U1 [get_ports {D[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {D[1]}]
# Connection: D(2) de Disp1of4Digit sur SW14 => T1
set_property PACKAGE_PIN T1 [get_ports {D[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {D[2]}]
# Connection: D(3) de Disp1of4Digit sur SW15 => R2
set_property PACKAGE_PIN R2 [get_ports {D[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {D[3]}]
#maintenant à vous de compléter un peu plus!
#n'oubliez pas de décommenter les lignes de compléter
# Connection: N(1) de Disp1of4Digit sur BTNR => T17
set_property PACKAGE_PIN T17 [get_ports {N[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {N[1]}]
# Connection: N(0) de Disp1of4Digit sur BTND => U17
set_property PACKAGE_PIN T1 [get_ports {N[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {N[0]}]
# On-board 7-segment Display #
# SEGMENTS
# Connection: S(6) de Disp1of4Digit sur �_vous => U7
set_property PACKAGE_PIN U7 [get_ports {S[6]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[6]}]
# Connection: S(5) de Disp1of4Digit sur �_vous => V5
set_property PACKAGE_PIN V5 [get_ports {S[5]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[5]}]
# Connection: S(4) de Disp1of4Digit sur �_vous => U5
set_property PACKAGE_PIN U5 [get_ports {S[4]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[4]}]
# Connection: S(3) de Disp1of4Digit sur �_vous => V8
set_property PACKAGE_PIN V8 [get_ports {S[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[3]}]
# Connection: S(2) de Disp1of4Digit sur �_vous => U8
set_property PACKAGE_PIN U8 [get_ports {S[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[2]}]
# Connection: S(1) de Disp1of4Digit sur �_vous => W6
set_property PACKAGE_PIN W6 [get_ports {S[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[1]}]
# Connection: S(0) de Disp1of4Digit sur �_vous => W7
set_property PACKAGE_PIN W7 [get_ports {S[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {S[0]}]
# ENABLE
# Connection: ENAN(3) de Disp1of4Digit sur AN3 => W4
set_property PACKAGE_PIN W4 [get_ports {ENAN[3]}]
set_property IOSTANDARD LVCMOS33 [get_ports {ENAN[3]}]
# Connection: ENAN(2) de Disp1of4Digit sur AN2 => V4
set_property PACKAGE_PIN V4 [get_ports {ENAN[2]}]
set_property IOSTANDARD LVCMOS33 [get_ports {ENAN[2]}]
# Connection: ENAN(1) de Disp1of4Digit sur AN1 => U4
set_property PACKAGE_PIN U4 [get_ports {ENAN[1]}]
set_property IOSTANDARD LVCMOS33 [get_ports {ENAN[1]}]
# Connection: ENAN(0) de Disp1of4Digit sur AN0 => U2
set_property PACKAGE_PIN U2 [get_ports {ENAN[0]}]
set_property IOSTANDARD LVCMOS33 [get_ports {ENAN[0]}]
On-board Timer
# CLOCK
# Connection: CLK de Cmpt0to3 sur W5
set_property PACKAGE_PIN W5 [get_ports {CLK}]
set_property IOSTANDARD LVCMOS33 [get_ports {CLK}]
```

## Annexe 4: Cmpt1to3 avec Des LUTs

BELLIARD & RAFIK 6 / 6

