# **DE1-SoC Tutorial**

## COE838: Systems-on-Chip Design Lab 3

## 1. Objectives

The purpose of this lab is to introduce students to the HPS/FPGA design flow involved in SoC design using the DE1-SoC development board. Students will create a hardware prototype in VHDL for the Cyclone V using Quartus II and QSys. Using ARM DS-5 and a serial terminal, students will also learn how to control (FPGA) hardware through embedded C programs running on a Yocto Linux operating system. This lab will therefore provide students with the fundamentals for prototyping SoC designs from both a hardware and software perspective.



Fig. 1: Block Diagram of the Cyclone V HPS/FPGA Device for DE1-SoC

## 2. DE1-SoC Overview

### 2.1 HPS/FPGA Cyclone V Device

A general block diagram of the DE1-SoC dev board is provided in Fig. 1. The DE1-SoC contains a Cyclone V device which comprises of two distinct components - an FPGA and Hard Processor System (HPS). The HPS is a hard logic (soft processor) microprocessor unit (MPU) consisting of a dual-core ARM Cortex-A9 processor, on-chip memories, SDRAM, L3 interconnect, and support and interface peripherals. The HPS will be used to execute the software portion of your SoC design.

The Cyclone V's FPGA component consists of FPGA fabric, standard FPGA components (LUTs, CLBs, PLL etc), shared memory controllers, and general peripherals found on a standard FPGA dev board. The FPGA is used to prototype hardware for your SoC design, receiving and sending data to and from the HPS using AXI buses, bridges, and Avalon master-slave devices.

As seen in Fig. 1, the HPS and FGPA components each have their own pins and peripherals on the device. Consequently, the pins are not freely shared between the HPS and FPGA fabric. The FPGA and HPS pins must therefore be designated at different stages of the design flow.

### 2.2 HPS/FPGA Communication

The HPS-to-FPGA and FPGA-to-HPS master/slave connection block diagram used by the Cyclone V is provided in Fig. 2. This figure gives a detailed outline of how the HPS, FPGA and its associated peripherals communicate through a series of bridges and AXI buses. As seen in the figure, there are 3 main bridges used for communication: the FPGA-to-HPS bridge (f2h), the HPS-to-FPGA bridge (h2f), and the Lightweight HPS-to-FPGA bridge (**lwh2f**). For this lab and subsequent labs, we will only be concerned with the lwh2f bridge. Although only the lwh2f HPS-to-FPGA communication is shown in Fig. 2, the slaves are allowed to communicate back to the HPS through the FPGA-to-SDRAM connections provided by the FPGA's Avalon Memory Mapped (MM) Master.



Fig. 2: HPS/FPGA Bus and Bridge Communication Block Diagram

| Region Name             | Description                                    | Base Address | Size  |
|-------------------------|------------------------------------------------|--------------|-------|
| FPGA Slaves             | For accessing FPGA slaves connected to the h2f | 0xC0000000   | 960MB |
|                         | bridge                                         |              |       |
| HPS Peripherals         | Accessing slaves directly connected to the HPS | 0xFC000000   | 64MB  |
| Lightweight FPGA Slaves | Accessing slaves connected to the lwh2f bridge | 0xFF200000   | 2MB   |

As seen in Fig. 1, the lwh2f bridge and AXI bus support a 32-bit datawidth between the HPS and FPGA (i.e one word). The HPS supports communication with the FPGA/peripherals through the L3 interconnect, which is connected to the HPS' (DDR3) SDRAM Controller. It is therefore essential that the SDRAM pins be configured correctly so that the HPS may read/write data to/from the SDRAM controller and establish communication between the L3 interconnect and FPGA.

Once all hardware has been correctly prototyped, communication between the HPS and FPGA is programmed through a memory mapped C application. Memory mapping allows the CPU to view and access the FPGA's address space (containing our components) so that we may read/write information as necessary, controlling the hardware through software. The C application you will develop uses APIs to send write (or receive read) data to (and from) specified memory addresses.

The IP components you add to your system each possess a base address. You will use the base addresses to access, control, and send data to and from your SoC components using your C application. These addresses will be generated for you as header files using the NIOS II Command shell. A general design flow can be seen in Fig. 3, with common base addresses given in Table I (the lightweight FPGA slave address will be of interest to your design).

Once your C application is complete, a binary is generated by compiling your software on a host computer. The binary must be placed on a USB which will be inserted and mounted to the HPS/FPGA system. You must then copy the binary from the USB to your HPS home directory to execute the application. Upon execution, the HPS will communicate with the FPGA prototype based on the APIs and functionality you have coded in your C application. You may access and interact with the HPS/ Yocto Linux OS from your host computer using a serial connection (minicom **or** the DS-5 terminal).

### 2.3 DE1-SoC HPS/FPGA Design Flow

The HPS/FPGA design flow is provided in Fig. 3. This figure outlines the design steps we will need to follow for prototyping a SoC design with a DE1-SoC based HPS/FPGA system.



Fig 3. Overall HPS/FPGA Design Flow for Altera's DE1-SoC



Fig. 4: Tools and Flow used for DE1-SoC Design

## 3. Tutorial

## 3.1 HPS/FPGA Design Structure Overview

There are many steps we must follow for designing a HPS/FPGA SoC. A structured block diagram outlining the general tools used for the hardware and software flows is given in Fig. 4. Consult this diagram when following the tutorial guide (along with Fig. 3) to understand what step you are currently executing in the SoC design flow. You will also be going back and forth between various development tools. Be prepared.

## 3.2 Hardware Design

## 3.2.1 Quartus Part-I

- 1. Open Quartus II 14.0. Note that you may only use **version 14.0** and above for Altera Cyclone V and Ryerson EE network compatibility.
- 2. Follow the directions to create a new project
  - a. On the home screen, select "New Project Wizard"
  - b. On the "Introduction" screen select "next"
  - c. Page [1 of 5]
    - i. In the first field, select your working directory- where you would like the project to be saved (preferable with a new folder name in your coe838 directory)
    - ii. Give a project name in the second field. This should be copied automatically to the third field. For the purpose of this lab, let's use "LED\_HEX\_FPGA".
    - iii. Select next
  - d. Page [2 of 5].
    - i. Select next
  - e. Page [3 of 5]
    - i. Under "Device Family" select Cyclone V
    - ii. Under "Package" select FBGA
    - iii. Under "Available Devices", select 5CSEMA5F31C6. Note you may also use the first few letters "5CSEMA5" in "name filter" to quickly find this device.
    - iv. Select Next
  - f. Page [4 of 5]
    - i. Under "Tool Type" "Simulation" select "ModelSim-Altera". Under "Formats" select VHDL
    - ii. Select Next
  - g. Page [5 of 5]
    - i. Verify that all the information you have specified in the previous steps is correct.
    - ii. Assuming all information is correct, select Finish.
  - h. Your Quartus II project workspace should now open and resemble Fig. 5.
- 3. Navigate to the COE838 course directory coe838/labs/lab3/rtl and copy all the **files** in the /rtl folder to your project folder.
- 4. Go back to coe838/labs/lab3 and copy the **/ip folder** (the entire folder, not the files inside) to your project directory. Ensure sure that your project folder now contains an /ip folder.
- 5. Go back to Quartus II. Select "Project" "Add/Remove files in project". Select the "..." button and select the LED\_HEX\_FPGA.vhd file. Press OK. Select ADD. Select Apply. Select OK.



Fig. 5: Quartus II Project Workspace

- 6. In Quartus' left pane "Project Navigator" window, double click "LED\_HEX\_FPGA". This should open the VHDL file we just added to the project. <u>If this does not occur</u>, select "File" "Open" LED\_HEX\_FPGA.vhd. Select "Project" "Set as Top-Level Entity". Then repeat step 6 to verify you have successfully selected this VHDL file as your top level-entity.
- 7. Observe the VHDL code provided to you. The entity contains keywords used by the Cyclone V for its HPS/FPGA pinouts. These names can be found in the *pin\_assignment\_DE1-SoC.tcl* file provided to you. Notice that there are comments noting where you should place the SoC component and it's port map given by QSys.

## 3.2.2 QSys

### a) Adding Components

- 1. In Quartus, select "Tools" "QSys". Wait for QSys to launch.
- 2. A window will open prompting you to select a file in your project folder. Select soc\_system.qsys and press Open.
- 3. Another window will open to verify the component list and their compatibility with QSys. Once it has finished verification, select Close.
- 4. A QSys system will open containing a clock source and HPS IP block. Make sure to use this .qsys template <u>for all your labs/project</u> as it contains HPS parameter mappings specifically for the DE1-SoC. We will now add the custom IP cores needed for our SoC and make the proper connections to the HPS/FPGA bridges.
- 5. In the QSys "IP Catalog" left window pane, expand "Project" "Terasic Technologies Inc". Highlight "SEG7\_IF" and select "+ Add..".
- 6. A SEG7\_IF parameters window will open. Ensure the following values are specified:
  - a. SEG7\_NUM: 6
  - b. ADDR\_WIDTH: 3
  - c. DEFAULT\_ACTIVE: 1
  - d. LOW\_ACTIVE: 1

Click finished in the SEG7\_IF window once complete.

- Next, we will add a Parallel I/O (PIO) IP block to the system. We will need this to access the LEDs on the FPGA. Select "Processors and Peripherals" - "Peripherals" - "PIO (Parallel I/O)". Press "+Add...".
- 8. A Parallel I/O parameters window will open. Ensure the following values are specified:
  - a. Width(1-32 bits): 10
  - b. Direction: Output

Note: the same PIO IP can be selected for accessing the Switches on the DE1-SoC.

Click Finish. Messages and warnings will appear in the bottom window. We will resolve these soon.

9. In the QSys "System Contents" window, follow the "Name" column, and right click "pio\_0". Select rename and change the default name to "led\_pio". We can leave SEG7\_IF\_0 since this name bares meaning. If you chose not to name the IP blocks with the names specified, be conscience of this fact when designing and coding your VHDL in Section 3.3.



Fig. 6: QSys System Components and Connections

#### **b)** Component Connections

- 1. Next we will use the "Connections" column in QSys to map the IP blocks to the HPS. Each empty circle signifies a connection that may be made between two or more component (ports) in your system. A black/filled circle signifies that a connection/signal has been established between the two components.
- 2. Follow clk\_0's clk (clk\_0.clk) connection down to the SEG7\_IF\_0 and led\_pio components. Establish a connection (i.e. press the empty circle to color black) between clk\_0.clk and:
  - SEG7\_IF\_0's *clock\_sink* port
  - led\_pio's *clk* port
- 3. Make a connection between clk\_0.clk\_reset and:
  - SEG7\_IF\_0's *clock\_sink\_reset* port
  - led\_pio's *reset* port
- 4. Follow hps\_0.h2f\_lw\_axi\_master and make a (slave) connection between:
  - SEG7\_IF\_0's *avalon\_slave* port
  - led\_pio's s1 port
- 5. Follow led\_pio's **external connection** port horizontally to its "export" field. There is a faded label which says "*Double-click to export*". Double click the field. A default name will appear called "led\_pio\_external\_connection". This process is referred to as exporting a **conduit**.

- 6. Similarly, export the SEG7\_IF\_0 conduit. It will be given the default name "seg7\_if\_0\_conduit\_end".
- 7. The base addresses present on the component conduits may overlap and generate an error in the Messages window. In QSys, select "System" "Assign Base Address". Your QSys system and connections should now resemble Fig. 6. There should also be no warnings or errors in the Messages window.

**Exporting Conduits** are used to create external connections so that other components may access and communicate with your IP. In this case, we export led\_pio and SEG7 so that the HPS system may communicate with these components.

Similarly, the **slave** connections you make in QSys allow the IPs to communicate with the FPGA fabric and HPS (using the lwh2f bridge/AXI bus and L3 interconnect). The slaves also possess base addresses that you may include in your memory mapped I/O software to control and communicated data to the IPs.

#### c) Generating the QSys System

- 1. In QSys, go to "Generate" "HDL Example". Under "HDL Language" select VHDL. Press 'Copy' to copy the template and paste the VHDL code to your top-level entity (in the ARCHITECTURE section). We will use this code as a basis for instantiating and port mapping the HPS component into your SoC design. Press 'Close' when you finish copying the code.
- 2. Next in QSys, select "Generate" "Generate HDL...".
- 3. The Generation window will open. Under Synthesis "Create HDL design files for synthesis:" select VHDL. Leave Create block symbol file (.bsf) enabled.
- 4. The directory in the field "Output Directory" should match your project directory, with an appended folder name "soc\_system" which will be created.
- 5. Click "Generate" at the bottom. This will save the QSys system and generate your custom SoC VHDL block called "soc\_system". Wait for the system to generate and select "Close" to close the generation window once complete.

At this point, QSys has generated: 1) the soc\_system VHDL files needed for your SoC design, 2) a .tcl script for HPS pin assignments and 3) a .qpf file that needs to be included in the Quartus project for successfully synthesizing this HPS/FPGA system.

Next, we will generate the header files required for our HPS C software design. These h files provide the names and base addresses of our QSys components. Therefore using these h files we can simply #include the hps\_0.h file in our code and virtually access these addresses through memory mapping.

- 6. In QSys, select Tools NIOS II Command Shell [gcc4].
- 7. This will open a terminal. *cd* to your project directory.
- 8. Once in your project directory, type *sopc-create-header-files*. A message will appear in the terminal stating that the header files have been generated.
- 9. In the NIOS terminal, create a folder called "software" with the command *mkdir software*. Move the generated header files to the software folder using the command *mv* \*.*h software*

- 10. Open the hps\_0.h file in a text editor to view the generated base addresses and constant names that you will use to memory map these IPs in your c code. Minimize this window.
- 11. Go back to the NIOS terminal and close it. In QSys select "File" "Save". Once saved, select "Finish" at the bottom to return back to Quartus II.

## 3.2.3 Quartus Part-II

#### a) Port Map the SoC System

- Using the HDL code copied from QSys, instantiate the soc\_system component in the ARCHITECTURE section.
   Note: Please use the ARCHITECTURE from QSys generated code. Use SIGNAL and PORTMAP part of the code from the Appendix.
- 2. Use the *u0: soc\_system* template obtained from QSys to port map the soc\_system ENTITY to your overall design. An example of the final VHDL can be found in the Appendix of this lab.
- Next, we need to include the SoC system generated by QSys in our project: In Quartus select "Project" - "Add/Remove Files in Project". Navigate to the folder *soc\_system/synthesis/* and select *soc\_system.qip*. Press OK. Select "Add" - "Apply" - "OK".

#### b) Pin Assignment

1. In Quartus II, select "Tools" - "Tcl Scripts...". Select *pin\_assignment\_DE1-SoC.tcl* and click Run. A popup window will show up when successful. Click OK.



**NOTE:** A **bug** exists in Quartus 14.0. If you see *hps\_sdram\_p0\_pin\_assignments.tcl* listed more than once as shown in Fig. 7(a), exit Quartus and restart. Repeat steps 1 and 2. Before going to the next step, ensure that the window lists the .tcl script once as in Fig. 7(b).

- 2. Next, select the *hps\_sdram\_p0\_pin\_assignments.tcl* and click Run. A popup window will show up when successful. Click OK.
- 3. Once complete, click Close on the .tcl script window.

#### c) Compile Design

1. The final step is now to compile the design. Select "Processing" - "Start Compilation". Assuming that the RTL is coded correctly, **no errors** should exist. However there will likely be multiple warnings. You may ignore these.

<sup>&</sup>lt;sup>1</sup> Obtained from *SoC-FPGA Design Guide 0.29* Draft, by EPFL's Sahand Kashani-Akhavan and Rene Beuchat

## 3.3 Software Design

- 1. On the EE network, navigate to Applications Engineering Altera Eclipse for DS-5. Launch the application.
- 2. Select your project workspace as the /software folder location you created earlier on. Press OK.

| C Project                                                                                                                              |                                      |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--|--|
| C Project<br>Create C project of selected type                                                                                         |                                      |  |  |
| Project name: HexLEDsSM<br>Use default location<br>Location: C\Users\Anita Tino\Documents\I<br>Choose file system: default -           | DS-5 WorkspaceUntegerSor             |  |  |
| Project type:<br>Bare-metal Executable<br>Executable<br>Executable<br>Hello World ANSI C Project<br>Shared Library<br>Makefile project | Toolchains:<br>DS-5 GCC<br>MinGW GCC |  |  |
| Show project types and toolchains only if they are supported on the platform  () () () () () () () () () () () () ()                   |                                      |  |  |

Fig. 8: Creating a New Project in DS-5

- 3. Create a new project by selecting "New" "C-Project". A window will show up. In the Project type window select "Executable" "Empty Project". Under Toolchains ensure the "DS-5 GCC" compiler is chosen. Name the project HexLEDsSW, ensure that your default project location is correct, and that your project specifications are identical to Fig. 8. Press Finish. Your workspace will appear.
- 4. Navigate to the course directory /*coe838/labs/lab3/software* and copy all the **.c and .h files** in this folder to your lab3 directory's */software* folder. Next, create a zip file of all the contents in your software folder (including the .h file generated by NIOS II shell) and call it *software.zip*.
- 5. Go back to DS-5 and select "File" "Import" "General" "Archive File". Click Next. Under "From archive file" select the browse button, navigate to your software folder and select the *software*.zip file. A list of files will show. Select "Finish". Your workspace will now have all the files included in your .zip file.
- 6. Libraries: Next, we will need to include the necessary libraries for compiling this project. Select "Project" "Properties" "C/C++ Build" "Settings". Under the "Tool Settings" tab go to "GCC C Linker" "Libraries". Select the from under the Libraries (-1) option. A window will popup. Type in *pthread* and press OK. Do this again to add the *m* and *rt* libraries.
- 7. **Includes:** Next, we must include a path specific to the Altera SoC hardware API files. In the same Project Properties window from step 6, navigate to "C/C++ General" "Path and Symbols" "Includes" tab, highlight **GNU C** and click "Add...". In the directory field type:

### /usr/local/Quartus-EDS-14.0/embedded/ip/altera/hps/altera\_hps/hwlib/include

and press OK. Select OK at the bottom of the Project Properties window.

8. Build your project using the shortcut CTRL-B or pressing the icon S. A successful build message should appear in the console window.

9. Next, plug in your USB to the host computer. Navigate to your */software* folder and into its **/Debug** folder. Assuming a successful build in Step 5, an executable file named *HexLEDsSW* (or the equivalent name which you gave your project) will exist. Copy this onto your USB stick. Eject the USB from the host computer.

#### 3.4 Hardware/Software Execution 3.4.1 Software Preparation

- 1. Power on the DE1-SoC board located at your workstation.
- 2. You may create a serial connection to the ARM processor (running Yocto Linux) in **one** of the following two ways:
  - a. **DS-5 Terminal** In DS-5, select "Window" "Show View" "Other" "Terminal" "Terminal". A window for specifying the serial connection details will appear. Ensure that the following is selected:
    - Connection Type: Serial
    - Baud Rate: 115200

The rest of the information should remain as defaulted. Press OK. In the terminal window select the *static content is a connection with HPS and its Linux OS.* 

#### OR

- b. **Minicom** On the host computer, open a terminal. Type *minicom SOC-USBO*. A connection will be established with the board opening a new window session within the terminal.
- 3. If no text is displayed in the terminal, press enter. A prompt from the OS will show up asking for login credentials. The first prompt will show:
  - socfpga login: bob
  - This signifies that your username is *bob*. Next a password prompt will show.
  - Password: bob
  - Thus your username and password is bob
- 4. Next, plug in your USB drive into one of the USB ports at the back of the DE1-SoC board. A message will appear listing that you have added a device to the system located at /dev/sda1. You now need to mount your USB to Linux so that you can access the files on your drive. To do this, in the serial terminal type *mount /mnt*
- 5. Since you do not have any executable privileges on your mounted device, you must copy your executable to your working directory. Do this by typing the command: *cp* /*mnt/HexLEDsSW*. (include the . when issuing the command to signify that you wish to copy the executable in the 1<sup>st</sup> argument to this directory).

#### **3.4.2 Hardware Preparation**

- 1. Now go back to **Quartus**. Launch the programmer by going to "Tools" "Programmer", or click the <sup>▶</sup> icon. The Quartus Programmer window will open.
- 2. Press the *Hardware Setup* button at the top left of the window. From the *Available hardware items* select DE1-SoC. Double click the field. This should change the *Currently selected hardware* to the DE1. If not, select it manually from the drop down list. Press close.
- 3. In the Programmer window's left panel, select *Auto Detect*. This will automatically detect the device connected to your host computer via JTAG. A popup window will appear, select the second option which reads "5CSEMA5" and press OK.

- 4. Next, we need to upload the .sof file to the FPGA. In the left pane, select "Add File...". Navigate to your project folder's *output\_files* folder and select the *HEX\_LED\_FPGA.sof* file. Once selected press OK.
- 5. Now you will have 3 chips/devices present in the programmer. Highlight the 5CSEMA5 device containing no .sof file (in the top window). Right click the device and select delete. You should now have the SOCVHPS and .sof device present in the programmer space as shown in Fig. 9.



Fig. 9: Quartus Programmer Window

6. In the Programmer's top window, make sure that the .sof device has a checkmark in the "Program/Configure" checkbox. In the left pane, select start. A status bar in the upper right corner will show the progress of your .sof bitstream upload to the DE1-SoC. You should also see a green light on the board. Wait until it is 100% successful. Your FPGA (hardware prototype) has now been successfully configured as an HPS/FPGA system.

## **3.4.3** Executing Applications (with embedded Linux - Yocto)

1. Switch back to the minicom (or DS-5 terminal) serial terminal. In the terminal, type in:

#### launcher HexLEDsSW

This will execute the binary (we cross-compiled in DS-5) as an application on your HPS/FPGA system. You should see the LEDs rotate and blink, and the HEX switch numbers and display a message at the end. To stop execution, simply press CTRL-C. The status of the SoC will also be displayed in the serial terminal.

2. Analyze the main.c file and it's support code files. Read the comments and understand the logistics of creating a software application for virtual memory mapping a HPS/FPGA system in Linux.

### 4. What to Hand In

Using the techniques learned throughout this tutorial, students are to design a custom HPS/FPGA SoC. The FPGA hardware prototype should consist of:

- 10 LEDs
- 10 Switches
- HEX display

The .c code running on the HPS must provide the following functionality:

- Upon startup of the application, a "light show" will occur with the LEDs and HEX display
- Once the light show has completed:
  - the HEX should display a message (other than "HELLO")
  - When a switch is pressed up, it's corresponding LED should light. When switched down, the LED should also turn off accordingly.
- Your program should display information pertaining to the mode and/or state your SoC system is during execution in the serial terminal.

This lab is due week 7. Please print out and hand in:

- All .c code implemented for your software design
- The hps\_0.h file generated with the NIOS II command shell
- The top-level VHDL you have used to design your hardware prototype
- A screenshot of your QSys system with all associated IP blocks and their respective connections.
- A screenshot of the terminal window for a sample execution of your SoC system.

The lab must be handed in with the Ryerson University cover page, dated and signed. Your lab instructor will also ask you to demo your work during submission. Be prepared.

<u>Note:</u> The switches and their state will need to be read using the Altera API. The *uint32\_t alt\_read\_word(uint32\_t address);* 

may be used to access a switch(es) state.

#### **Hints:**

<sup>-</sup>Several other API functions exist including *alt\_setbits\_word()* and *alt\_clrbits\_word()* that may help in your code design. <u>To access these function declarations</u>: In DS-5, hover over an instance of *alt\_write\_word(..)* and press CTRL and left-click the mouse. This will create a link and DS-5 will navigate to the function's declaration. This declaration file will also contain multiple API functions you will likely need for your lab.

<sup>-</sup> The Switch(es) pin names that must be used in your VHDL can be found in pin\_assignment\_DE1-SoC.tcl.

#### **Appendix**

------- HED\_LED\_FPGA Tutorial -- Lab 3 -- COE838 Systems-on-Chip Design -- Created By: Anita Tino library ieee; use ieee.std\_logic\_1164.all; use ieee.numeric std.all; ENTITY LED\_HEX\_FPGA IS PORT( CLOCK 50, HPS DDR3 RZQ, HPS ENET RX CLK, HPS ENET RX DV : IN STD LOGIC; : OUT STD\_LOGIC\_VECTOR(14\_DOWNTO 0); : OUT STD\_LOGIC\_VECTOR(2\_DOWNTO 0); HPS\_DDR3\_ADDR HPS DDR3 BA HPS\_DDR3\_CS\_N : OUT STD\_LOGIC; HPS DDR3\_CK\_P, HPS\_DDR3\_CK\_N, HPS\_DDR3\_CKE : OUT STD\_LOGIC; HPS\_USB\_DIR, HPS\_USB\_NXT, HPS\_USB\_CLKOUT : IN STD LOGIC; : IN STD\_LOGIC; : IN STD\_LOGIC\_VECTOR(3 DOWNTO 0); HPS\_DDB3\_DOS\_N : INOUT\_STD\_LOGIC\_VECTOR(3 DOWNTO 0); : INOUT STD\_LOGIC\_VECTOR(3 DOWNTO 0); : INOUT STD\_LOGIC\_VECTOR(3 DOWNTO 0); HPS\_DDR3\_DQS\_P : INOUT STD\_LOGIC; HPS ENET MDIO HPS USB DATA : INOUT STD LOGIC VECTOR(7 DOWNTO 0); HPS DDR3 DQ : INOUT STD LOGIC VECTOR(31 DOWNTO 0); 

 HPS\_DDR3\_DQ
 : INCOT CTD\_DCTC.(CT DIMENSION)

 HPS\_SD\_CMD
 : INCOT CTD\_DCTC.(CT DIMENSION)

 HPS\_ENET\_TX\_DATA, HPS\_DDR3\_DM
 : OUT STD\_LOGIC\_VECTOR(3 DOWNTO 0);

 HPS\_DDR3\_ODT, HPS\_DDR3\_RAS\_N, HPS\_DDR3\_RESET\_N HPS\_DDR3\_CAS\_N, HPS\_DDR3\_WE\_N - : OUT STD\_LOGIC; : OUT STD LOGIC; HPS ENET MDC, HPS ENET TX EN : OUT STD LOGIC; : OUT STD LOGIC VECTOR(9 DOWNTO 0); LEDR HEX0, HEX1, HEX2, HEX3, HEX4, HEX5: BUFFER STD\_LOGIC\_VECTOR(6 DOWNTO 0); HPS USB STP, HPS SD CLK, HPS ENET GTX CLK : OUT STD LOGIC); END LED HEX FPGA; ARCHITECTURE Behaviour OF LED HEX FPGA IS component soc\_system is (clk\_clk : in std\_logic hps\_0\_h2f\_reset\_reset\_n : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TX\_CLK : out std\_logic; port (clk clk := 'X'; hps\_io\_hps\_io\_emacl\_inst\_TX\_CLK : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TXD1 : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TXD1 : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TXD2 : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TXD3 : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_MDI0 : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_MDI0 : out std\_logic; := 'X'; := 'X'; hps\_io\_hps\_io\_emacl\_inst\_MDC : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_RX\_CTL : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_RX\_CTL : out std\_logic; := 'X'; hps io hps io emac1 inst TX CTL : out std logic; nps\_lo\_nps\_lo\_emacl\_inst\_IX\_CTL : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_RX\_CLK : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_RXD1 : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_RXD2 : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_RXD3 : in std\_logic hps\_io\_hps\_io\_sdio\_inst\_CMD : inout std\_logic := 'X'; := 'X'; := 'X'; hps\_lo\_nps\_to\_emact\_inst\_RXD3 hps\_io\_hps\_io\_emac1\_inst\_CMD hps\_io\_hps\_io\_sdio\_inst\_CMD := 'X'; := 'X'; : inout std\_logic : inout std\_logic : out std\_logic; : inout std\_logic; : inout std\_logic hps\_io\_hps\_io\_sdio\_inst\_D0 hps\_io\_hps\_io\_sdio\_inst\_D1 := 'X'; := 'X'; hps\_io\_hps\_io\_sdio\_inst\_CLK hps\_io\_hps\_io\_sdio\_inst\_D2 := 'X'; hps\_io\_hps\_io\_sdio\_inst\_D3 hps\_io\_hps\_io\_usbl\_inst\_D0 := 'X'; := 'X'; hps\_io\_hps\_io\_usb1\_inst\_D1 hps\_io\_hps\_io\_usb1\_inst\_D2 := 'X'; := 'X'; : inout std\_logic hps\_io\_hps\_io\_usb1\_inst\_D3 hps\_io\_hps\_io\_usb1\_inst\_D4 := 'X'; := 'X'; hps\_io\_hps\_io\_usbl\_inst\_D5 hps\_io\_hps\_io\_usbl\_inst\_D6 := 'X'; := 'X'; hps\_io\_hps\_io\_usbl\_inst\_D7 hps\_io\_hps\_io\_usbl\_inst\_CLK : inout std logic := 'X'; := 'X'; hps\_io\_hps\_io\_usbl\_inst\_STP hps\_io\_hps\_io\_usbl\_inst\_DIR := 'X'; hps io hps io usb1 inst NXT := 'X'; memory mem a : out std\_logic\_ : out std\_logic; memory mem ba std logic vector(2 downto 0); memory mem ck : out std\_logic; : out std\_logic; memory mem ck n memory mem cke : out std\_logic; : out std logic; memory\_mem\_cs\_n memory mem ras n : out std\_logic; : out std\_logic; : out std\_logic; : out std\_logic; : inout std\_logic; : inout std\_logic\_vector(31 downto 0) := (others => 'X'); memory mem cas n memory mem we n memory\_mem\_reset\_n memory mem dq

: inout std\_logic\_vector(3 downto 0) := (others => 'X'); : inout std\_logic\_vector(3 downto 0) := (others => 'X'); memory\_mem\_dqs memory mem dqs n memory\_mem\_odt : out std\_logic; : out std\_logic\_vecc. : in std\_logic in std\_logic : restor(47 do std\_logic\_vector(3 downto 0); memory mem dm := 'X'; memory oct rzqin reset\_reset\_n := 'X'; seg7\_if\_0\_conduit\_end\_export : out std logic vector(47 downto 0); led\_pio\_external\_connection\_export : out std\_logic\_vector(9 downto 0)); end component soc\_system; SIGNAL hex5 tmp, hex4 tmp, hex3 tmp, hex2 tmp, hex1 tmp, hex0 tmp, hps 0 h2f reset reset n : STD LOGIC; BEGIN u0 : component soc system port map ( clk clk => CLOCK\_50, => '1', => HPS\_DDR3\_ADDR, reset\_reset\_n memory mem a => HPS DDR3 BA, memory mem ba => HPS\_DDR3\_CK\_P, => HPS\_DDR3\_CK\_N, memory mem ck memory mem ck n => HPS\_DDR3\_CKE, => HPS\_DDR3\_CS\_N, memory mem cke memory mem cs n => HPS\_DDR3\_RAS\_N, => HPS\_DDR3\_CAS\_N, memory\_mem\_ras\_n memory mem cas n => HPS DDR3 WE N, memory mem we n => HPS DDR3 RESET N, memory mem reset n => HPS\_DDR3\_DQ, => HPS\_DDR3\_DQS\_P, memory mem dq memory mem dqs => HPS\_DDR3\_DQS\_N, => HPS\_DDR3\_ODT, memory mem dqs n memory\_mem\_odt => HPS\_DDR3\_DM, => HPS\_DDR3\_RZQ, memory\_mem\_dm memory oct rzqin hps\_io\_hps\_io\_emacl\_inst\_TX\_CLK hps\_io\_hps\_io\_emacl\_inst\_TXD0 => HPS\_ENET\_GTX\_CLK, => HPS\_ENET\_TX\_DATA(0), hps\_io\_hps\_io\_emacl\_inst\_TXD1 hps\_io\_hps\_io\_emacl\_inst\_TXD2 => HPS\_ENET\_TX\_DATA(1), => HPS\_ENET\_TX\_DATA(2), hps\_io\_hps\_io\_emac1\_inst\_TXD3 hps\_io\_hps\_io\_emac1\_inst\_RXD0 => HPS\_ENET\_TX\_DATA(3), => HPS\_ENET\_RX\_DATA(0), hps\_io\_hps\_io\_emacl\_inst\_MDIO hps\_io\_hps\_io\_emacl\_inst\_MDC => HPS ENET MDIO, => HPS ENET MDC, hps\_io\_hps\_io\_emacl\_inst\_RX\_CTL hps\_io\_hps\_io\_emacl\_inst\_TX\_CTL => HPS\_ENET\_RX\_DV, => HPS\_ENET\_TX\_EN, > HPS\_ENET\_RX\_CLK, => HPS\_ENET\_RX\_DATA(1), hps\_io\_hps\_io\_emac1\_inst\_RX\_CLK hps\_io\_hps\_io\_emac1\_inst\_RXD1 hps\_io\_hps\_io\_emac1\_inst\_RXD2 hps\_io\_hps\_io\_emac1\_inst\_RXD3 => HPS\_ENET\_RX\_DATA(2), => HPS\_ENET\_RX\_DATA(3), hps\_io\_hps\_io\_sdio\_inst\_CMD hps\_io\_hps\_io\_sdio\_inst\_D0 => HPS\_SD\_CMD, => HPS\_SD\_DATA(0), hps\_io\_hps\_io\_sdio\_inst\_D0 hps\_io\_hps\_io\_sdio\_inst\_D1 hps\_io\_hps\_io\_sdio\_inst\_D2 hps\_io\_hps\_io\_sdio\_inst\_D3 hps\_io\_hps\_io\_usb1\_inst\_D0 hps\_io\_hps\_io\_usb1\_inst\_D1 hps\_io\_hps\_io\_usb1\_inst\_D3 hps\_io\_hps\_io\_usb1\_inst\_D3 hps\_io\_hps\_io\_usb1\_inst\_D4 hps\_io\_hps\_io\_usb1\_inst\_D5 hps\_io\_hps\_io\_usb1\_inst\_D6 => HPS\_SD\_DATA(1), => HPS\_SD\_CLK, => HPS\_SD\_DATA(2), => HPS\_SD\_DATA(3), => HPS\_USB\_DATA(0), => HPS\_USB\_DATA(1), => HPS\_USB\_DATA(2), => HPS\_USB\_DATA(3), => HPS\_USB\_DATA(4), => HPS\_USB\_DATA(5), hps\_io\_hps\_io\_usb1\_inst\_D6 hps\_io\_hps\_io\_usb1\_inst\_D7 => HPS\_USB\_DATA(6), => HPS\_USB\_DATA(7), hps\_io\_hps\_io\_usb1\_inst\_CLK hps\_io\_hps\_io\_usb1\_inst\_STP => HPS\_USB\_CLKOUT, => HPS\_USB\_STP, hps\_io\_hps\_io\_usb1\_inst\_DIR hps\_io\_hps\_io\_usb1\_inst\_NXT => HPS USB DIR, => HPS USB NXT, hps 0 h2f\_reset\_reset\_n => hps 0 h2f reset reset n, led pio\_external\_connection\_export => LEDR, seg7\_if\_0\_conduit\_end\_export(47) => hex5\_tmp, seg7\_if\_0\_conduit\_end\_export(46 DOWNTO 40)=>HEX5, seg7 if 0 conduit end export(39) =>hex4 tmp, seg7 if 0 conduit end export(38 DOWNTO 32)=>HEX4, seg7 if 0 conduit end export(31) =>hex3 tmp, seg7 if 0 conduit end export(30 DOWNTO 24)=>HEX3, seg7\_if\_0\_conduit\_end\_export(30 bown10 24) > maxs, seg7\_if\_0\_conduit\_end\_export(23) seg7 if 0 conduit end export(22 DOWNTO 16)=> HEX2, =>hex2\_tmp, seg7\_if\_0\_conduit\_end\_export(12 DOWNTO 10)-> HEX2, seg7\_if\_0\_conduit\_end\_export(15) seg7\_if\_0\_conduit\_end\_export(14 DOWNTO 8) => HEX1, seg7\_if\_0\_conduit\_end\_export(7) seg7\_if\_0\_conduit\_end\_export(6 DOWNTO 0) =>HEX0 => hex1 tmp, => hex0 tmp, );

End Behaviour;