# Interfacing Custom IP Cores to HPS/FPGA SOC Platform

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

## 1. Objectives

This lab provides students with a brief tutorial on how to interface IP cores to HPS/FPGA systems. Therefore the knowledge obtained in Lab 3 is a pre-requisite for this lab. Students will learn how to integrate custom IP cores into their design, and create Avalon Memory Map (MM) slaves to interface these cores with HPS/FPGA based SoCs. Students will then apply this knowledge by interfacing IP(s) into a SoC design of their choice.

## 2. Hardware Design

#### 2.1 Project Setup

Create a Quartus II project called *custom\_ip* in your COE838 lab folder, setting up the necessary parameters for a HPS/FPGA system with the Cyclone-V 5CSEMA5F31C6 device. Create a new VHDL file called *custom\_ip.vhdl* and set it as your top-level entity. Next we will add an Altera-based IP core to the project (formerly known as MegaCore). For the sake of this lab, we will include a customized multiplier IP (which will be integrated to a HPS/FPGA SoC and interfaced with Avalon MM slaves).

- 1. To include the multiplier IP core, in Quartus go to "Tools" "IP Catalog". A window will appear on the right.
- 2. Expand the field "Library" "Basic Functions" "Arithmetic". Double click "LPM\_MULT". A window will appear.
- 3. This window requires you to name your IP core and select the directory to create/save the IP. Name the IP "mult" and ensure that the project directory listed is correct. Under "IP variation file type" select VHDL. Press OK.
- 4. Another window will appear (may take some time) presenting the MegaWizard Plug-in Manager. Using this wizard, we will specify the parameters of our custom multiplier IP.
  - a. [Parameter Settings > General] Page
    - i. Under "Multiplier Configuration" ensure "multiply 'dataa' by 'datab' input" is selected.
    - ii. Select the datawidth of dataa to be 16 bits.
    - iii. Select the datawidth of datab to be 16 bits.
    - iv. Ensure that the result datawidth is 32 bits.
    - v. Press Next
  - b. [Parameter Settings > General2] Page
    - i. Ensure the three defaulted bullet selections read "No", "Unsigned", and "Use the Default implementation" respectively.

- ii. Press Next.
- c. [Parameter Settings > Pipelining] Page
  - i. Under the "Pipelining" subsection, select the option "Yes, I want an output latency of **3** clock cycles", writing the number 3 in the blank field.
  - ii. Enable "Create an 'aclr' synchronous port".
  - iii. Enable "Create a 'clken' clock enable clock".
  - iv. Leave optimization as "Default".
  - v. Press Next.
- d. [EDA] Page
  - i. Select Next
- e. [Summary] Page
  - i. Ensure "mult.vhd" is enabled by default.
  - ii. Ensure mult.cmp is also enabled.
  - iii. The rest of the options should be disabled. The LPM\_MULT component block diagram should resemble that of Fig. 1.
  - iv. Press "Finish".

| DPM_MULT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                             | About Documentation                                                                                                                                                                                                                                                                                                                    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 Parameter 2 EDA 3 Sum<br>Settings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | nary                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                        |
| dataaj15.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Turn on the files you wi<br>automatically generate<br>to generate the selecte<br>MegaWizard Plug-In Ma<br>The MegaWizard Plug-I<br>C: \Users\Anita Tino\Ord | sh to generate. A gray checkmark indicates a file that is<br>d, and a green checkmark indicates an optional file. Click Finish<br>d files. The state of each checkbox is maintained in subsequent<br>nager sessions.<br>n Manager creates the selected files in the following directory:<br>pobx/COCE33/kub4/custom_jo - Lab Tutorial/ |
| multiplication                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | File                                                                                                                                                        | Description                                                                                                                                                                                                                                                                                                                            |
| cken                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ✓ mult.vhd                                                                                                                                                  | Variation file                                                                                                                                                                                                                                                                                                                         |
| Contraction of the second seco | mult.inc                                                                                                                                                    | AHDL Include file                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | mult.cmp                                                                                                                                                    | VHDL component declaration file                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | mult.bsf                                                                                                                                                    | Quartus II symbol file                                                                                                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | mult_inst.vhd                                                                                                                                               | Instantiation template file                                                                                                                                                                                                                                                                                                            |
| Resource Usage                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                             | Cancel < Back hext > Einish                                                                                                                                                                                                                                                                                                            |

Fig. 1: LPM\_MULT Summary

5. The multiplier IP will now be generated in Quartus according to the specifications provided. Include this design in your Quartus project by selecting "Project" - "Add/Remove Files in Project..." and select mult.qip, press Add..., and press OK. You may find the multiplier declaration to instantiate the component in your VHDL design in *mult.vhd*.

#### 2.2 IP Wrapper

The multiplier IP we created contains two inputs, a clock source, an asynchronous reset, and an enable signal. Thus when we create our HPS .c program we will have no issue writing our values and setting up the IP for execution. However, how will we be able to determine when the multiplier has completed computing by simply using our HPS software?

We specified in the MegaCore Wizard that the multiplier should take 3 clock-cycles to execute. Therefore we must create a type of IP "wrapper" which will input all the signals to the multiplier when enabled, and count three clock cycles before outputting a "done" flag to signal to the HPS that the multiplier's product is ready to be read.

The wrapper for the mult IP is located in the course folder at /*coe838/labs/lab4/rtl/mult\_unit.vhd*. This VHDL file includes the multiplier IP component we just generated called "mult" and port maps it, while creating a wrapper with the functionality described above, i.e. the done signal is pipelined 3 times before outputting the *mult\_done* signal. Ensure that your mult IP is identical to the component instantiated in this VHDL file, else make the necessary corrections.

#### 2.3 Avalon MM Slave Interface Design

In the previous lab, we used Altera's built-in QSys compatible *pio* and *SEG7\_IF* components which had their own custom Avalon MM slave design embedded into their component. However because we created our own IP from the MegaWizard and would like to include it in our SoC design, we must create our own Avalon MM slave design and incorporate it into our SoC using QSys. This MM slave design allows our IP to communicate on the FPGA fabric and be controlled through the HPS C code we will develop.

As seen in lab 3, memory mapping allows our software to communicate with our hardware components (through the Avalon/AXI bus and lwh2f bridge). However when our IP contains multiple ports, we need to specify these addresses. For example, writing to address 0x0001 + *virtual\_base\_address* allows us to write data to our mult's dataa port (using the HPS software), writing to address 0x0002 *virtual\_base\_address* writes to mult's datab port, reading from 0x0000 + *virtual\_base\_address* reads the product output once complete etc. In lab 3, our pio and SEG7\_IF only had one input port to which we wrote data, and was interpretted by the IP to turn on the appropriate LEDs etc. Now our component possess multiple ports and we must be able to handle this communication using bus interfaces.

To make our slave designs concise and simple, we will use the easiest bus interface - the Avalon MM interface. The Avalon MM employs a master-slave protocol with the CPU acting as a master, and the FPGA peripherals acting as slaves. We will create two Avalon MM slaves for the multiplier SoC and classify them into the categories control and data- called *mult\_control* and *mult\_data* respectively. These VHDL files can be found in the *coe838/labs/lab4/rtl* folder (*mult\_control.vhdl* and *mult\_data.vhdl*). Copy them to your project directory. Open these files to view the VHDL.

| Name          | Width                | Direction | Comments                        |
|---------------|----------------------|-----------|---------------------------------|
| avs_address   | <= 64 bits           | Input     | Address of slave being accessed |
| avs_read      | 1 bit                | Input     | Read operation requested        |
| avs_write     | 1 bit                | Input     | Write operation requested       |
| avs_readdata  | 8, 16, 32 or 64 bits | Output    | Data read from slave            |
| avs writedata | 8, 16, 32 or 64 bits | Input     | Data to be written to slave     |

Table I: Common Avalon Bus Signals

The contents in the Avalon MM slave VHDL files look like any standard VHDL file, however they contain keywords to properly identified Avalon bus signals in QSys. In particular, the avs\_\* prefix signifies to QSys that this port communicates with Avalon bus, where other signals usually imply exported conduits, clocks, reset etc. Table I provides common signal names and characteristics used by MM slaves for the Avalon bus.

Let us take *mult\_control.vhdl* as an example to obtain an understanding for Avalon MM bus interface design. In terms of control in the multiplier IP, we will need a reset, enable, and done signal for handling control from the HPS software. Therefore our C code will send out the reset and start signals to the multiplier, and read the done signal to determine completion. Looking at *mult\_control.vhdl*, we include the mult\_\* ports so that we may export them as conduits in QSys, and then port map them directly from the HPS to the multiplier to provide this control. The avs\_\* ports are used to read the control addresses and data from the FPGA  $\rightarrow$  Avalon bus  $\rightarrow$  HPS, and the reverse for writes. Therefore as seen in this VHDL code, if our C application were to *write* to mult\_control\_base + 0x0000, we would be writing to the IP's start signal, whereas mult\_control\_base + 0x0001 would write to the reset signal etc. Similarly if we would like to read the status of the multiplier's done signal, we would read from the mult\_control\_base + 0x0010 address. The other signals are used for debugging and ensuring that the signals are the value we expect (such as reset is unasserted to calculate etc).

The same concept is applied to the *mult\_data* bus for reading and writing data. Notice that all data based ports are 32 bits so that we may easily access the bus and conduits with the alt\_read\_word() and alt\_write\_word() APIs in the HPS while following the Avalon bus conditions specified in Table I. A graphical representation of the SoC and Avalon MM slaves discussed here is presented in Fig. 2.



Fig. 2: Multiplier SoC Avalon MM Slave Interface

#### 2.4 Creating the SoC Hardware

#### 2.4.1 QSys Component Creation and SoC Design

Next, we will create a SoC with the Avalon MM slave interfaces using QSys. Copy the soc\_system.qsys file from the */coe838/labs/lab3* directory that we used in the previous lab to your project directory. Open QSys and the soc\_system.qsys file. We will now learn how to create new QSys components for the Avalon MM slaves we designed and include them in our SoC design.

1. In QSys' left window pane, double-click *New Component*.... This will open a component editor window.

- 2. [Component Type] Page
  - a. In the Name field, highlight new\_component and overwrite it with *mult\_control*.
  - b. Also call the Display name field *mult\_control*
- 3. [Files] Page
  - a. Under **Synthesis Files** select the "+" button. A browse window will open. Select *mult\_control.vhdl* and press Open.
  - b. Click the "Analyze Synthesis Files" button. A status window will open signifying that your VHDL file is being synthesized and analyzed as a component. Once complete, a message will appear stating that QSys has finished analyzing the files. Press Close. You will likely see errors pop up in the Message tab. Ignore these for now.
- 4. Skip to [Signals] Page
  - a. The avs\_\* keyword signal names should be correctly recognized by QSys and interfaced as "s0" type i.e. an Avalon slave. Clk and reset should also be classified as clock and reset respectively. However the mult\_\* signals will likely be misinterpreted. We must correct these signals and place them as conduit interfaces.
  - b. At mult\_start, press its interface name field (i.e. likely called *avalon\_slave\_0*). This will open a drop down menu. Select *new Conduit...*. This will rename the interface to *conduit\_end*. Under signal type, type in *m\_start* (can be given any unique name besides Avalon keyword names).
  - c. For mult\_reset, open the interface drop down menu and select *conduit\_end* so that all the conduits are classified under the same name. Rename it's signal type to a name of your choice i.e. *m\_reset*
  - d. Repeat step c. for the mult\_done signal.
- 5. [Interface] Page
  - a. Click "Remove Interfaces With No Signals". This will remove several messages from the QSys Message window. We will resolve the remaining errors using this page.
  - b. Every "Associated Clock" and "Associated Reset" field for all interfaces listed will need to be specified with a clock and reset respectively. Therefore for all the interfaces listed on this page, use the drop down menu to select the clock and/or reset signal listed if "None" is specified as its type. All messages will disappear after this step.
  - c. Next, we would like to name our conduits something more meaningful other than *conduit\_end*. Therefore scroll to the "conduit\_end (Conduit)" interface and type *mult\_control* in the Name field. Press Enter to set the change in the Block Diagram displayed.
  - d. Double check that all parameters have been specified as described in the steps above. Once you are confident with these parameters, press "Finish".
  - e. A window will show prompting you to save the changes to a .tcl file. Press "Yes, Save".

- 6. You will be brought back to the main QSys page, with a new component listed in the IP catalog under the **Project** heading called *mult\_control*. Highlight *mult\_control* and press the "+Add..." button. Press Finish to successfully add it to your SoC.
- 7. Connect the *mult\_*control\_0.clock port to clk\_0.clk in your *Connections*.
- 8. Connect mult\_control\_0.reset port to clk\_0.reset.
- 9. Connect mult\_control\_0.s0 to hps\_0.h2f\_lw\_axi\_master.
- 10. Export the mult\_control\_0.mult\_control conduit. There should now be no errors or warnings in the QSys Message window.
- 11. Repeat steps 1 5 to create a new component for the mult\_data Avalon MM interface.
- 12. Repeat steps 6 10 for the mult\_data component using the port names you specified during component creation.
- 13. Resolve any base address overlaps (refer to Lab 3).
- 14. Copy the HDL example that QSys generated for you and place it in your project's top-level entity file.
- 15. In QSys, Generate HDL to create the VHDL for your project's SoC system.
- 16. Once successfully generated, use the NIOS II shell to generate.h files for your C application.
- 17. Exit QSys by selecting Finish. Include the soc\_system.qip file in your Quartus project.

#### 2.4.2 Finalizing the Quartus Project

Finally, we need to integrate the SoC design with our multiplier using your *custom\_ip* top-level entity file. Use the sample top-level file provided to you in lab 3 (*HEX\_LED\_FPGA.vhd*) with the sample HDL you copied in QSys to code your top-level VHDL. Omit any reference to HEX and LEDR in the *HEX\_LED\_FPGA* ENTITY, and rename the ENTITY to *custom\_ip*. Port map the start, reset and done conduits from the soc\_system to its respective ports in the multiplier. Similarly, port map the in1, in2, and result conduits from the soc\_system to the multiplier.

You will find a top-level VHDL sample to reference in the Appendix of this lab if you are having difficulties. Note that the port names may vary depending on what you named your Avalon interface conduits in the mult\_control and mult\_data slaves (in QSys).

Once you have completed your top-level VHDL design, run the two .tcl scripts for mapping the pin assignments. Compile your design, correct any errors and successfully generate a .sof file to program the FPGA.

## 3. Software Design

A sample .c application can be found in *coe838/labs/lab4/software*. Copy the main.c file to your project's software directory which contains the \*.h files you generated using the NIOS II shell. Open the file to view its contents.

The general template for coding the application is the same as Lab 3. The only difference is that now you have more addresses to work with, and must apply an offset to your API virtual base address depending on what signals/ports you are trying to access when reading (alt\_read\_word) or writing (alt\_write\_word) to mult\_data and mult\_control. You must use the Avalon MM slave VHDL files to obtain the offset that should be applied to the virtual base address.

**Note:** you may use this main.c file for compiling and generating a binary for the next step. However ensure that the hps\_0.h file's component names and base addresses correctly reflect your QSys system components. If they do not match, make the changes needed to the .c file accordingly.

Create a project in DS-5 and compile the .c application to generate a binary. Copy the binary to a USB.

## 4. HPS/FPGA Execution

Power on the DE1-SoC board. Upload the .sof file to the FPGA using the Quartus II Programmer. Insert the USB to the HPS, mount it using the Linux command, copy the binary to your home directory and execute it. Your terminal output should resemble that of Fig. 3.

| Iteration 27<br>Reset done. Deasserting signal<br>Start successful<br>waiting for done<br>conversion done<br>0x0000001b * 0x0000001c = 0x000002f4. [Expected] 0x000002f4<br>[SUCCESSFUL] |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Reset done. Deasserting signal<br>Start successful<br>waiting for done<br>conversion done<br>0x000001c * 0x0000001d = 0x0000032c. [Expected] 0x0000032c<br>[SUCCESSFUL]                  |  |
| Reset done. Deasserting signal<br>Start successful<br>waiting for done<br>conversion done<br>0x0000001d * 0x0000001e = 0x00000366. [Expected] 0x00000366<br>[SUCCESSFUL]                 |  |
| Reset done. Deasserting signal<br>Start successful<br>waiting for done<br>conversion done<br>0x000001e * 0x0000001f = 0x000003a2. [Expected] 0x000003a2<br>[SUCCESSFUL]                  |  |
| [TEST PASSED] 30/30                                                                                                                                                                      |  |

Fig. 3: Sample output from Multiplier SoC

## 5. What To Hand In

Using the interfacing methodology introduced in this lab, students are to create a HPS/FPGA SoC integrating an IP core of their choice. This core may be selected from the IP Catalog (MegaCore), designed as a custom IP, or retrieved from other IP sources (OpenCores, etc). Marks will be awarded based on creativity and complexity of the design.

This lab is due in week 8/9. When submitting your lab, please include:

- All VHDL files used in your design including the top-level file and all Avalon MM Slave(s) VHDL for interfacing your hardware design. Include any IP VHDL that you believe is relevant to the design (i.e. wrapper, declaration etc).
- A snapshot of your QSys system
- All .c files used for your HPS application
- The hps 0.h file generated by the NIOS II Shell.
- Output of your SoC execution in the HPS terminal.

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

#### <u>Appendix</u>

library IEEE; use IEEE.std\_logic\_1164.all; use IEEE.numeric std.all; ENTITY custom\_ip IS PORT ( CLOCK 50, HPS DDR3 RZQ, HPS ENET RX CLK, HPS ENET RX DV : IN STD LOGIC; HPS\_DDR3\_ADDR : OUT STD\_LOGIC\_VECTOR(14\_DOWNTO 0); : OUT STD\_LOGIC\_VECTOR(2\_DOWNTO 0); HPS DDR3 BA HPS\_DDR3\_CS\_N HPS\_DDR3\_CK\_P, HPS\_DDR3\_CK\_N, HPS\_DDR3\_CKE : OUT STD\_LOGIC; : IN STD LOGIC; HPS\_USB\_DIR, HPS\_USB\_NXT, HPS\_USB\_CLKOUT - : IN STD\_LOGIC; : IN STD\_LOGIC\_VECTOR(3 DOWNTO 0); HPS ENET RX DATA : INOUT STD\_LOGIC\_VECTOR(3 DOWNTO 0); : INOUT STD\_LOGIC\_VECTOR(3 DOWNTO 0); : INOUT STD\_LOGIC; HPS SD DATA, HPS DDR3 DQS N HPS DDR3 DQS P HPS ENET MDIO HPS USB DATA : INOUT STD LOGIC VECTOR (7 DOWNTO 0); HPS DDR3 DQ : INOUT STD LOGIC VECTOR (31 DOWNTO 0); HPS SD CMD : INOUT STD LOGIC; 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 : OUT STD\_LOGIC; HPS\_DDR3\_CAS\_N, HPS\_DDR3\_WE\_N : OUT ST : OUT STD\_LOGIC; : OUT STD\_LOGIC; HPS\_ENET\_MDC, HPS\_ENET\_TX\_EN HPS\_USB\_STP, HPS\_SD\_CLK, HPS\_ENET\_GTX\_CLK : OUT STD\_LOGIC); END ENTITY custom\_ip; ARCHITECTURE Behaviour of custom ip IS component soc system is port(clk clk : in std\_logic := 'X'; std logic; hps 0 h2f reset reset n : out hps\_io\_hps\_io\_emacl\_inst\_TX\_CLK hps\_io\_hps\_io\_emacl\_inst\_TXD0 hps\_io\_hps\_io\_emacl\_inst\_TXD1 : out std\_logic; : out std\_logic; : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_TXD2 hps\_io\_hps\_io\_emacl\_inst\_TXD3 : out std logic; : out std\_logic; hps\_io\_hps\_io\_emacl\_inst\_RXD0 : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_RXD0 : inout std\_logic := 'X'; := 'X'; : inout std\_logic : out std\_logic; : in std\_logic : out std\_logic; : in std\_logic : in std\_logic : in std\_logic : in std\_logic hps\_io\_hps\_io\_emacl\_inst\_MDC hps io hps io emacl inst RX CTL := 'X'; hps\_io\_hps\_io\_emacl\_inst\_TX\_CTL hps\_io\_hps\_io\_emacl\_inst\_RX\_CLK := 'X'; hps\_io\_hps\_io\_emacl\_inst\_RXD1 hps\_io\_hps\_io\_emacl\_inst\_RXD2 := 'X'; := 'X'; hps\_io\_hps\_io\_emacl\_inst\_RXD2 hps\_io\_hps\_io\_emacl\_inst\_RXD3 hps\_io\_hps\_io\_sdio\_inst\_CMD hps\_io\_hps\_io\_sdio\_inst\_D1 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\_D2 hps\_io\_hps\_io\_usb1\_inst\_D2 hps\_io\_hps\_io\_usb1\_inst\_D2 hps\_io\_hps\_io\_usb1\_inst\_D2 hps\_io\_hps\_io\_usb1\_inst\_D2 := 'X'; : inout std\_logic := 'X'; : inout std\_logic := 'X'; : inout std logic := 'X'; : out std\_logic; : inout std\_logic := 'X'; : inout std logic := 'X'; : inout std\_logic := 'X'; : inout std\_logic : inout std\_logic := 'X'; := 'X'; hps\_io\_hps\_io\_usb1\_inst\_D3 hps\_io\_hps\_io\_usb1\_inst\_D4 : inout std\_logic : inout std\_logic := 'X'; := 'X'; hps\_io\_hps\_io\_usb1\_inst\_D5 hps\_io\_hps\_io\_usb1\_inst\_D6 : inout std\_logic : inout std logic := 'X'; := 'X'; hps\_io\_hps\_io\_usb1\_inst\_D7 hps\_io\_hps\_io\_usb1\_inst\_CLK : inout std\_logic := 'X'; : in std\_logic : out std\_logic; : in std\_logic : in std\_logic : in std\_logic := 'X'; hps\_io\_hps\_io\_usb1\_inst\_STP hps\_io\_hps\_io\_usb1\_inst\_DIR := 'X'; hps\_io\_hps\_io\_usb1\_inst\_NXT memory\_mem\_a := 'X'; : in std\_logic : out std\_logic\_vector(14 downto 0); : out std\_logic\_vector(2 downto 0); : out std\_logic; memory mem ba memory mem ck : out std\_logic; memory\_mem\_ck\_n memory mem cke 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 memory\_mem\_dm : out std\_logic; : out std\_logic\_vector(3 downto 0); memory\_oct\_rzqin : in std logic := 'X';

reset\_reset\_n : in std\_logic := 'X'; mult\_control\_0\_mult\_control\_m\_start : out std\_logic\_vector(31 downto 0); mult\_control\_0\_mult\_control\_m\_reset : out std\_logic\_vector(31 downto 0); mult\_control\_0\_mult\_control\_m\_done : in std\_logic\_vector(31 downto 0) := (others => 'X'); mult\_data\_0\_mult\_data\_m\_in1 : out std\_logic\_vector(31 downto 0); mult\_data\_0\_mult\_data\_m\_in2 : out std\_logic\_vector(31 downto 0); mult\_data\_0\_mult\_data\_m\_result : in std\_logic\_vector(31 downto 0) := (others => 'X') end COMPONENT soc system; COMPONENT mult\_unit T mult\_unit PORT( clk, reset, enable : IN STD\_LOGIC; mult\_a, mult\_b : IN STD LOGIC VECTOR (15 DOWNTO 0); mult\_done : OUT STD LOGIC; mult result : OUT STD LOGIC VECTOR(31 DOWNTO 0) := (others => '0')); END COMPONENT: SIGNAL reset\_reset\_n, done : STD\_LOGIC ; SIGNAL mult\_input\_reset : STD\_LOGIC\_VECTOR(31 DOWNTO 0); SIGNAL mult\_output\_result, mult\_input\_start : STD\_LOGIC\_VECTOR(31 DOWNTO 0); SIGNAL in1, in2 : STD\_LOGIC\_VECTOR(31 DOWNTO 0); BEGIN u0 : component soc system port map ( clk clk => CLOCK\_50, => '1', reset reset n => HPS\_DDR3\_ADDR, memory\_mem\_a memory\_mem\_ba => HPS DDR3 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 memory\_mem\_ras\_n => HPS\_DDR3\_RAS\_N, => HPS DDR3 CAS N, memory\_mem\_cas\_n memory\_mem\_we\_n => HPS\_DDR3\_WE\_N, memory\_mem\_reset\_n => HPS\_DDR3\_RESET\_N, memory mem dq => HPS DDR3 DQ, => HPS\_DDR3\_DQS\_P, => HPS\_DDR3\_DQS\_N, memory\_mem\_dqs memory mem dqs n => HPS\_DDR3\_ODT, memory\_mem\_odt memory\_mem\_dm => HPS\_DDR3\_DM, memory\_oct\_rzqin => HPS\_DDR3\_RZQ, hps\_io\_hps\_io\_emac1\_inst\_TX\_CLK hps\_io\_hps\_io\_emac1\_inst\_TXD0 hps\_io\_hps\_io\_emac1\_inst\_TXD1 => HPS\_ENET\_GTX\_CLK, >> HPS\_ENET\_TX\_DATA(0), >> HPS\_ENET\_TX\_DATA(1), >> HPS\_ENET\_TX\_DATA(1), => HPS\_ENET\_TX\_DATA(2), => HPS\_ENET\_TX\_DATA(3), hps io hps io emac1 inst TXD2 hps\_io\_hps\_io\_emac1\_inst\_TXD3 hps io hps io emac1 inst RXD0 => HPS ENET RX DATA(0), hps\_io\_hps\_io\_emac1\_inst\_MDIO => HPS ENET MDIO, hps\_io\_hps\_io\_emac1\_inst\_MDC hps\_io\_hps\_io\_emac1\_inst\_RX\_CTL => HPS\_ENET\_MDC, => HPS ENET RX DV, hps\_io\_hps\_io\_emacl\_inst\_TX\_CTL hps\_io\_hps\_io\_emacl\_inst\_RX\_CLK => HPS\_ENET\_TX\_EN, => HPS\_ENET\_RX\_CLK, hps\_io\_hps\_io\_emacl\_inst\_RXD1 hps\_io\_hps\_io\_emacl\_inst\_RXD2 => HPS\_ENET\_RX\_DATA(1), => HPS\_ENET\_RX\_DATA(2), hps\_io\_hps\_io\_emacl\_inst\_RXD3 hps\_io\_hps\_io\_sdio\_inst\_CMD => HPS ENET RX DATA(3), => HPS SD CMD, hps\_io\_hps\_io\_sdio\_inst\_D0 hps\_io\_hps\_io\_sdio\_inst\_D1 hps\_io\_hps\_io\_sdio\_inst\_D1 hps\_io\_hps\_io\_sdio\_inst\_CLK hps\_io\_hps\_io\_sdio\_inst\_D2 => HPS SD DATA(0), => HPS\_SD\_DATA(1), => HPS SD CLK, => HPS\_SD\_DATA(2), hps\_io\_hps\_io\_sdio\_inst\_D3 hps\_io\_hps\_io\_usbl\_inst\_D0 => HPS SD DATA(3), => HPS USB DATA(0), => HPS\_USB\_DATA(1), => HPS\_USB\_DATA(2), hps\_io\_hps\_io\_usb1\_inst\_D1 hps\_io\_hps\_io\_usb1\_inst\_D2 hps\_io\_hps\_io\_usbl\_inst\_D2 hps\_io\_hps\_io\_usbl\_inst\_D3 hps\_io\_hps\_io\_usbl\_inst\_D4 hps\_io\_hps\_io\_usbl\_inst\_D5 hps\_io\_hps\_io\_usbl\_inst\_D6 => HPS\_USB\_DATA(3), => HPS\_USB\_DATA(4), => HPS\_USB\_DATA(5), => HPS\_USB\_DATA(6), hps\_io\_hps\_io\_usbl\_inst\_D7 hps\_io\_hps\_io\_usbl\_inst\_CLK hps\_io\_hps\_io\_usbl\_inst\_STP hps\_io\_hps\_io\_usbl\_inst\_DIR => HPS\_USB\_DATA(7), => HPS\_USB\_CLKOUT, => HPS USB STP, => HPS\_USB\_DIR, hps io hps io usb1 inst NXT => HPS USB NXT, => reset\_reset\_n, => mult\_output\_result, hps\_0\_h2f\_reset\_reset\_n mult\_data\_0\_mult\_data\_m\_result 

END Behaviour;