

## **Introduction à l'outil Platform Designer**

Ce TP présente une introduction à l'outil Intel® Platform Designer, qui permet de concevoir des systèmes matériels numériques contenant des composants tels que des processeurs, des mémoires, des interfaces d'entrée/sortie, des timers, etc. L'outil Platform Designer permet à un concepteur de choisir les composants souhaités dans le système en sélectionnant ces composants dans une interface utilisateur graphique. Il génère ensuite automatiquement le système matériel qui relie tous les composants entre eux.

Le flux de développement du système matériel est illustré en donnant des instructions étape par étape pour utiliser l'outil Platform Designer avec le logiciel Quartus pour implémenter un exemple de système simple. La dernière étape du processus de développement consiste à configurer le système matériel conçu dans un périphérique FPGA réel et à exécuter un programme d'application

- 1) Créer un nouveau projet Quartus comme indiqué dans la figure 1.



2) Ouvrir le fichier soc\_0.vhd. Le contenu du fichier est indiqué dans la figure 2



The screenshot shows the Quartus Prime Lite Edition interface with the following details:

- File Menu:** File, Edit, View, Project, Assignments, Processing, Tools, Window, Help.
- Toolbar:** Includes icons for Open, Save, Undo, Redo, Cut, Copy, Paste, Find, etc.
- Project Navigator:** Shows a Cyclone V: 5CSEMA5F31C6 device and an Entity: Instance named soc\_0.
- Editor Area:** Displays the VHDL code for soc\_0.vhd. The code defines an entity soc\_0 with inputs CLOCK\_50, KEY, SW, and outputs LEDR, HEX0, HEX1, HEX2, and HEX3. It also defines an architecture nios\_computer\_rtl for soc\_0.

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.numeric_std.ALL;

ENTITY soc_0 IS
PORT (
    -- Inputs
    CLOCK_50: IN STD_LOGIC;
    KEY : IN STD_LOGIC_VECTOR (1 DOWNTO 0);
    SW : IN STD_LOGIC_VECTOR (7 DOWNTO 0);

    -- Outputs
    LEDR: OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
    HEX0: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX1: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX2: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX3: OUT STD_LOGIC_VECTOR (6 DOWNTO 0)
);
END soc_0;

ARCHITECTURE nios_computer_rtl OF soc_0 IS
BEGIN
END nios_computer_rtl;
```

- Tasks Panel:** Shows a list of tasks under 'Compilation': Compile Design, Analysis & Synthesis, Fitter (Place & Route), Assembler (Generate program), and Timing Analysis.
- Bottom Panels:** Includes a toolbar with icons for All, Filter, Find, and Find Next, and a message log panel with columns for Type, ID, and Message.

3) Dans la fenêtre Tools, choisir Platform Designer



- 4) L'outil Platform Designer s'ouvre. Enregister le système comme



## 5) Enregistrer le système comme **nios2\_computer.qsys**



- 6) Chercher dans IP catalog le processeur « nios ii processor ». Le sélectionner comme indiqué en bleu dans la figure suivante et cliquer sur « Add »



7) La fenêtre de nios ii processor s'ouvre. Cliquer « finish » dans la fenêtre « Nios II Processor »



4) Le nios ii s'ajoute au soc comme indiqué sur la figure suivante



6) Chercher « on\_chip memory » dans IP catalog et faire « Add »



- 8) Changer « Total memory size » de 4096 byte à 40960 bytes dans la fenêtre « On-chip memory ». Cliquer « Finish » dans la fenêtre « On-chip memory ».



## 9) Chercher JTAG UART dans « IP Catalog » et faire « Add »



## 8) Ne rien changer. Cliquer « finish » dans la fenêtre JTAG UART



## 10) Chercher pio dans IP catalog



11) Ne rien changer et cliquer « Finish » sur la fenêtre PIO

Parameters  

Parameters 

**System:** nios2\_computer **Path:** pio\_0

**PIO (Parallel I/O) Intel FPGA IP**  
altera\_avalon\_pio

**Basic Settings**

Width (1-32 bits):

Direction:  Bidir  
 Input  
 InOut  
 Output

Output Port Reset Value:

**Output Register**

Enable individual bit setting/clearing

**Edge capture register**

Synchronously capture

Edge Type:

Enable bit-clearing for edge capture register

**Interrupt**

Generate IRQ

IRQ Type:

**Level:** Interrupt CPU when any unmasked I/O pin is logic true  
**Edge:** Interrupt CPU when any unmasked bit in the edge-capture register is logic true. Available when synchronous capture is enabled

**Test bench wiring**

|| | | |  nios2\_computer:nios2\_gen2\_0 | EX

12) Changer le nom de pio\_0 à LEDs



13) Cliquer « Add ». Choisir ce pio comme Input. Cliquer sur « Finish » dans la fenêtre pio



14) Changer le nom de pio\_0 à Switches



### 15) Chercher System ID dans IP catalog et cliquer « Add »



### 16) Choisir System ID=0x1234. Cliquer « finish » dans la fenêtre System ID



## 17) Chercher pio dans IP catalog



## 18) Configurer la fenêtre suivante comme indiqué dans la figure suivante



### 19) Changer le nom de pio\_0 à Key1



### 20) Relier le « clk » au nios et à tous les périphériques comme indiqué dans les deux figures suivantes



## 21) Relier le Data master à tous les périphériques

The screenshot shows two instances of the Qsys System Catalog interface, likely from a tool like Quartus Prime.

**Top Window:**

- Project:** nios2\_computer
- Library:** PIO (Parallel I/O) Intel FPGA IP
- System Contents:** Path: Key1.s1
- Connections Table:**

| Use | Connections             | Name                                  | Description | Export                 | Clock  | Base   | End    |
|-----|-------------------------|---------------------------------------|-------------|------------------------|--------|--------|--------|
|     | clk                     | clock output                          |             | Double-click to export | clk_0  |        |        |
|     | clk_reset               | reset output                          |             | Double-click to export |        |        |        |
|     | nios2_gen2_0            | Nios II Processor                     |             |                        |        |        |        |
|     | clk                     | clock input                           |             | Double-click to export | clk_0  |        |        |
|     | reset                   | reset input                           |             | Double-click to export | [clk]  |        |        |
|     | data_master             | Avalon Memory Mapped Master           |             | Double-click to export | [clk]  |        |        |
|     | instruction_master      | Avalon Memory Mapped Master           |             | Double-click to export | [clk]  |        |        |
|     | irq                     | Interrupt Receiver                    |             | Double-click to export | [clk]  |        |        |
|     | debug_reset_request     | Reset Output                          |             | Double-click to export | [clk]  |        |        |
|     | debug_mem_slave         | Avalon Memory Mapped Slave            |             | Double-click to export | [clk]  |        |        |
|     | custom_instruction_m... | Custom Instruction Master             |             | Double-click to export | [clk]  |        |        |
|     | onchip_memory2_0        | On-Chip Memory (RAM or ROM) Intel ... |             | Double-click to export | clk_0  |        |        |
|     | clk1                    | clock input                           |             | Double-click to export | [clk1] | 0x0000 | 0x5fff |
|     | s1                      | Avalon Memory Mapped Slave            |             | Double-click to export | [clk1] | 0x0000 | 0x5fff |
|     | reset1                  | Reset Input                           |             | Double-click to export | [clk1] | 0x0000 | 0x5fff |
|     | jtag_uart_0             | JTAG UART Intel FPGA IP               |             | Double-click to export | clk_0  |        |        |
|     | clk                     | clock input                           |             | Double-click to export | [clk]  |        |        |
|     | reset                   | Reset Input                           |             | Double-click to export | [clk]  |        |        |
|     | avalon_jtag_slave       | Avalon Memory Mapped Slave            |             | Double-click to export | [clk]  | 0x0000 | 0x0007 |
|     | irq                     | Interrupt Sender                      |             | Double-click to export | [clk]  | 0x0000 | 0x0007 |
|     | LEDs                    | PIO (Parallel I/O) Intel FPGA IP      |             | Double-click to export | clk_0  |        |        |
|     | clk                     | clock input                           |             | Double-click to export | [clk]  |        |        |
|     | reset                   | Reset Input                           |             | Double-click to export | [clk]  |        |        |
|     | s1                      | Avalon Memory Mapped Slave            |             | Double-click to export | [clk]  | 0x0000 | 0x000f |
|     | external_connection     | Conduit                               |             | Double-click to export |        |        |        |
- Bottom Window:**
- Project:** nios2\_computer
- Library:** PIO (Parallel I/O) Intel FPGA IP
- System Contents:** Path: nios2\_gen2\_0.data\_master
- Connections Table:**

| Use | Connections         | Name                               | Description | Export                 | Clock | Base   | End    |
|-----|---------------------|------------------------------------|-------------|------------------------|-------|--------|--------|
|     | jtag_uart_0         | JTAG UART Intel FPGA IP            |             | Double-click to export | clk_0 |        |        |
|     | clk                 | clock input                        |             | Double-click to export | [clk] |        |        |
|     | reset               | Reset Input                        |             | Double-click to export | [clk] |        |        |
|     | avalon_jtag_slave   | Avalon Memory Mapped Slave         |             | Double-click to export | [clk] | 0x0000 | 0x0007 |
|     | irq                 | Interrupt Sender                   |             | Double-click to export | [clk] | 0x0000 | 0x0007 |
|     | LEDs                | PIO (Parallel I/O) Intel FPGA IP   |             | Double-click to export | clk_0 |        |        |
|     | clk                 | clock input                        |             | Double-click to export | [clk] |        |        |
|     | reset               | Reset Input                        |             | Double-click to export | [clk] |        |        |
|     | s1                  | Avalon Memory Mapped Slave         |             | Double-click to export | [clk] | 0x0000 | 0x000f |
|     | external_connection | Conduit                            |             | Double-click to export |       |        |        |
|     | Switches            | PIO (Parallel I/O) Intel FPGA IP   |             | Double-click to export | clk_0 |        |        |
|     | clk                 | clock input                        |             | Double-click to export | [clk] |        |        |
|     | reset               | Reset Input                        |             | Double-click to export | [clk] |        |        |
|     | s1                  | Avalon Memory Mapped Slave         |             | Double-click to export | [clk] | 0x0000 | 0x000f |
|     | external_connection | Conduit                            |             | Double-click to export |       |        |        |
|     | sysid_qsys_0        | System ID Peripheral Intel FPGA IP |             | Double-click to export | clk_0 |        |        |
|     | clk                 | clock input                        |             | Double-click to export | [clk] |        |        |
|     | reset               | Reset Input                        |             | Double-click to export | [clk] |        |        |
|     | control_slave       | Avalon Memory Mapped Slave         |             | Double-click to export | [clk] | 0x0000 | 0x0007 |
|     | Key1                | PIO (Parallel I/O) Intel FPGA IP   |             | Double-click to export | clk_0 |        |        |
|     | clk                 | clock input                        |             | Double-click to export | [clk] |        |        |
|     | reset               | Reset Input                        |             | Double-click to export | [clk] |        |        |
|     | s1                  | Avalon Memory Mapped Slave         |             | Double-click to export | [clk] | 0x0000 | 0x000f |
|     | external_connection | Conduit                            |             | Double-click to export |       |        |        |
|     | irq                 | Interrupt Sender                   |             | Double-click to export | [clk] | 0x0000 | 0x0007 |

## 22) Relier Instruction master avec la mémoire



23) Dans la fenêtre System, cliquer « Create Global Reset Network »



On obtient ceci



24) Faire la liaison JTAG UART au IRQ en cliquant le petit rond comme indiqué. Il va y avoir la valeur 0



25) Pour le périphérique LEDs, double cliquer à l'intersection « external connexion » et Export comme indiqué dans la figure suivante



## 26) Faire la même chose pour Switches et Key1



## 27) Faire la liaison Key1 au IRQ en cliquant le petit rond comme indiqué



28) Dans la fenêtre System, cliquer « Assign Base Address »

29) Double cliquer sur le « nios2\_gen2\_0 » et le configurer comme indiqué dans la figure suivante.  
Fermer la fenêtre après configuration



30) Cliquer « Generate HDL »



31) Choisir VHDL dans la figure suivante et cliquer « Generate »



32) Après la génération du VHDL, la fenêtre suivante s'affiche. Cliquer « Close »



33) Dans la fenêtre « Generate », cliquer « Show Instantiation Template »



34) Cliquer « Copy »



35) Ouvrir le fichier soc\_0.vhd. Copier le code VHDL dans le fichier.

```

LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE ieee.numeric_std.ALL;

ENTITY soc_0 IS

PORT(
    -- Inputs
    CLOCK_50: IN STD_LOGIC;
    KEY    : IN STD_LOGIC_VECTOR (1 DOWNTO 0);

    SW      : IN STD_LOGIC_VECTOR (7 DOWNTO 0);

    -- Outputs
    LEDR: OUT STD_LOGIC_VECTOR (7 DOWNTO 0);
)

```

```

    HEX0: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX1: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX2: OUT STD_LOGIC_VECTOR (6 DOWNTO 0);
    HEX3: OUT STD_LOGIC_VECTOR (6 DOWNTO 0)
  );
END soc_0;

```

ARCHITECTURE nios\_computer\_rtl OF soc\_0 IS

```

component nios2_computer is
port (
  clk_clk      : in std_logic      := 'X';      -- clk
  key1_external_connection_export : in std_logic      := 'X';      -- export
  leds_external_connection_export  : out std_logic_vector(7 downto 0);      -- export
  reset_reset_n        : in std_logic      := 'X';      -- reset_n
  switches_external_connection_export : in std_logic_vector(7 downto 0) := (others => 'X')  --
export
);
end component nios2_computer;

begin

  u0 : component nios2_computer
  port map (
    clk_clk      => CONNECTED_TO_clk_clk,          -- clk.clk
    key1_external_connection_export      => CONNECTED_TO_key1_external_connection_export,
    leds_external_connection_export     => CONNECTED_TO_leds_external_connection_export,
    reset_reset_n        => CONNECTED_TO_reset_reset_n,
    switches_external_connection_export => CONNECTED_TO_switches_external_connection_export      );

```

END nios\_computer\_rtl;

36) Ajouter le fichier nios2\_computer.qip dans le projet Quartus  
(C:\GE41\soc\_0\nios2\_computer\synthesis)



Category: Device/Board...

General

Files **(Selected)**

Libraries

IP Settings

- IP Catalog Search Locations
- Design Templates

Operating Settings and Conditions

- Voltage
- Temperature

Compilation Process Settings

- Incremental Compilation

EDA Tool Settings

- Design Entry/Synthesis
- Simulation
- Board-Level

Compiler Settings

- VHDL Input
- Verilog HDL Input
- Default Parameters
- Timing Analyzer
- Assembler
- Design Assistant
- Signal Tap Logic Analyzer
- Logic Analyzer Interface
- Power Analyzer Settings
- SSN Analyzer

**Files**

Select the design files you want to include in the project. Click Add All to add all design files in the project directory to the project.

File name:  ... Add X Add All

Remove Up Down Properties

| File Name | Type | Library | Design Entry/Synthesis Tool | HDL Version |
|-----------|------|---------|-----------------------------|-------------|
|           |      |         |                             |             |



37) Dans le fichier soc\_0.vhd, faire les liaisons avec les entrées et les sorties de la carte comme ceci

```

u0 : component nios2_computer
port map (
    clk_clk          => clock_50,
    key1_external_connection_export  => key(1),      -- key1_external_
    leds_external_connection_export   => ledr(7 downto 0),  -- led
    reset_reset_n     => key(0),      -- key
    switches_external_connection_export => sw(7 downto 0)  -- switches_exten
);
  
```

38) Compiler le projet Quartus

39) Ouvrir Intel FPGA Monitor Program. Créer un nouveau projet comme indiqué sur la figure suivante



40) Choisir les options comme indiqué sur la figure suivante



- 41) Sélectionner le programme en C
- 42) Ajouter le fichier test.c



43) Les spécifications mémoires sont comme ceci



- 44) Cliquer sur Save
- 45) Continuer dans TP2. Exécuter le programme test.c sur la carte.  
Remarque : le message suivant va apparaître sur l'écran. Le laisser et ne pas cliquer.



