## **SOC Design**

## LAB 1 - 111061545 陳揚哲

## Brief introduction about the overall system

In lab 1, we get the pre-code of the multiplication. Before implementation, we add the C++ source code and header file to Vitis and the test file to testbench. In first step, we should set the top function for export RTL (IP). In lab 1, we don't need to set up the directives since using #pargma. Then, we can start simulation and synthesis. After synthesis, we can start Cosimulation. In this step, we can see the waveform. Finally, we can use vivado to connect the ZYNQ and our multiplication IP. We have to generate the wrapper and bitstream for PYNQ access the design.

### What is observed & learned

In this lab, we understand the basic HLS flow, use top function for export RTL. Generate the wrapper for PYNQ access the design. It's necessary to wrapped in Python package for Jupyter operate based on overlay.

## Screen Dump

#### Performance:

# Utilization:

| == Utilization Est                                                        |                               |                      |                         |                  |                           |      |      |      |     |
|---------------------------------------------------------------------------|-------------------------------|----------------------|-------------------------|------------------|---------------------------|------|------|------|-----|
| * Summary:                                                                | ++                            | +                    |                         |                  | ++                        |      |      |      |     |
| Name                                                                      | BRAM_18KI                     | DSP I                | FF                      | LUT              | URAMI                     |      |      |      |     |
| IDSP<br> Expression<br> FIFO                                              | - <br>  - <br>  -             | - i<br>- l<br>- l    | -                       | -<br>-           | - <br>  - <br>  -         |      |      |      |     |
| DSP Expression FIFO Instance Memory Multiplexer Register Total            | 0 <br>  - <br>  -             | 31<br>-1<br>-1       | 309                     | 282              | - <br>  - <br>  -         |      |      |      |     |
| Total                                                                     | 1 -1<br>++<br>1 01            | - I<br>3 I           | 400                     | 307              | 1 -1<br>++<br>1 01        |      |      |      |     |
| t<br> Available                                                           | ++<br>I 2801                  | 2201                 | 106400                  | 53200            | ++<br>I 01                |      |      |      |     |
| +                                                                         | ++                            | +                    |                         |                  | ++                        |      |      |      |     |
| Utilization (%)                                                           | ++                            | +                    |                         |                  | ++                        |      |      |      |     |
| + Detail:<br>* Instance:                                                  |                               |                      |                         |                  |                           |      |      |      |     |
| 4                                                                         |                               |                      | Modula                  |                  |                           | DCD! | +    | +-   | IID |
| Insta                                                                     | nce I                         |                      | Module                  |                  |                           | DSP1 | +    | +-   | UK. |
| control_s_axi<br> mul_32s_32s_3                                           | _U<br>2_2_1_U1                | mul_32               | l_s_ax1<br>ls_32s_32    | 2_1              | 01                        | 31   | 1651 | 501  |     |
| Total                                                                     | <br> <br>+                    |                      |                         | <br> <br>+       | 01                        | 31   | 3091 | 2821 |     |
| * DSP:<br>N/A                                                             |                               |                      |                         |                  |                           |      |      |      |     |
| * Memory:<br>N/A                                                          |                               |                      |                         |                  |                           |      |      |      |     |
| * FIFO:<br>N/A                                                            |                               |                      |                         |                  |                           |      |      |      |     |
| * Expression:<br>N/A                                                      |                               |                      |                         |                  |                           |      |      |      |     |
| * Multiplexer:                                                            |                               |                      |                         |                  |                           |      |      |      |     |
| Name   LUT                                                                | +<br>I Input Si               | zel Bi               | ts  Tota                | l Bitsl          |                           |      |      |      |     |
| Name   L01<br>  Lap_NS_fsm   25<br>  Total   25                           | +<br>                         | 51                   | 11                      | 51               |                           |      |      |      |     |
| Total 1 25                                                                | +                             | 51                   | 11                      | +<br>51          |                           |      |      |      |     |
| +                                                                         | +                             | +                    | +                       | +                |                           |      |      |      |     |
| * Register:                                                               |                               |                      |                         |                  |                           |      |      |      |     |
| l Name                                                                    | i FF i                        | LUT                  | Bitsl Co                | nst Bits         | s I                       |      |      |      |     |
| tap_CS_fsm<br> mul_ln10_reg_69<br> n32In1_read_reg_<br> n32In2_read_reg_+ | 1 321<br>64 1 321<br>59 1 321 | 01<br>01<br>01<br>01 | 41<br>321<br>321<br>321 | (<br>(<br>(<br>( | -+<br>) <br>) <br>) <br>) |      |      |      |     |
| +ITotal                                                                   | 1 1001                        | 01                   | 1001                    |                  | -+<br>)                   |      |      |      |     |
| +                                                                         | +                             | +-                   | +                       |                  | +                         |      |      |      |     |

# Interface:

| ====================================== |         |       |             |                |               |  |  |  |  |  |  |  |  |
|----------------------------------------|---------|-------|-------------|----------------|---------------|--|--|--|--|--|--|--|--|
|                                        |         |       |             |                |               |  |  |  |  |  |  |  |  |
| * Summary:                             |         |       |             |                |               |  |  |  |  |  |  |  |  |
| I RTL Ports                            | D:      | Dital | Dantanal    | Course Object  | C Tuna        |  |  |  |  |  |  |  |  |
| RIL POTTS                              | l Dir l | Bitsl | Protocol I  | Source Object! | C Type        |  |  |  |  |  |  |  |  |
| le evi control AWVALID                 | in l    | 11    | o oril      |                | nointar!      |  |  |  |  |  |  |  |  |
| Is_axi_control_AWVALID                 | l inl   | 11    | s_axil      | controll       | pointer       |  |  |  |  |  |  |  |  |
| Is_axi_control_AWREADY                 | out     |       | s_axil      | controll       | pointer       |  |  |  |  |  |  |  |  |
| Is_axi_control_AWADDR                  | inl     | 61    | s_axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_WVALID                  | inl     | 11    | s_axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| s_axi_control_WREADY                   | out     | 11    | s_axi       | controll       | pointer       |  |  |  |  |  |  |  |  |
| s_axi_control_WDATA                    | l in    | 321   | s_axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_WSTRB                   | l in    | 41    | s_axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_ARVALID                 | l in    | 11    | s_axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_ARREADY                 | out     | 11    | s_axi       | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_ARADDR                  | l in    | 61    | s_axi       | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_RVALID                  | out     | 11    | s_axi       | control        | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_RREADY                  | l in l  | 11    | s_axil      | controll       | pointer       |  |  |  |  |  |  |  |  |
| ls_axi_control_RDATA                   | l out l | 321   | s_axi       | controll       | pointer       |  |  |  |  |  |  |  |  |
| Is axi control RRESP                   | l out l | 21    | s_axil      | controll       | pointer       |  |  |  |  |  |  |  |  |
| Is axi control BVALID                  | l out l | 11    | s axil      | control        | pointer       |  |  |  |  |  |  |  |  |
| Is axi control BREADY                  | l in l  | 11    | s axil      | controll       | pointer       |  |  |  |  |  |  |  |  |
| Is_axi_control_BRESP                   | outl    | 21    | s axil      | controll       | pointerl      |  |  |  |  |  |  |  |  |
| lap clk                                | l inl   | 11    | ap ctrl hsl | multip_2numl   | return valuel |  |  |  |  |  |  |  |  |
| lap rst n                              | l in l  | 11    | ap ctrl hsl | multip 2numl   | return valuel |  |  |  |  |  |  |  |  |
| lap start                              | i ini   | îί    | ap ctrl hsl | multip_2numl   | return valuel |  |  |  |  |  |  |  |  |
| lap done                               | outl    | îi    | ap ctrl hsl | multip 2numl   | return valuel |  |  |  |  |  |  |  |  |
| lap_idle                               | outl    | îi    | ap ctrl hsl | multip 2numl   | return valuel |  |  |  |  |  |  |  |  |
| lap_ready                              | outl    | îi    | ap_ctrl_hsl | multip_2numl   | return valuel |  |  |  |  |  |  |  |  |
| +                                      | ++      | +     | +           | +              | +             |  |  |  |  |  |  |  |  |

### Cosimulation waveform:



## Jupyter Notebook execution results: