## Traineeships in Advanced Computing for High Energy Physics (TAC-HEP)

## **FPGA module training**

Week-6

Lecture-11: 04/03/2025



WISCONSIN-MADISON

Varun Sharma

University of Wisconsin – Madison, USA





- Vivado/Vitis HLS Setup
  - First project

# Reminder: HLS Setup

- -

- ssh <username>@cmstrigger02-via-login -L5901:localhost:5901
  - Or whatever: 1 display number
  - Sometimes you may need to run vncserver -localhost -geometry 1024x768 again to start new vnc server
- Connect to VNC server (remote desktop) client
- Open terminal
  - source /opt/Xilinx/Vivado/2020.1/settings64.st
  - cd /scratch/`whoami`
  - vivado\_hls

## OR

- Source /opt/Xilinx/Vitis/2020.1/settings64.sh
- Cd /scratch/`whoami`
- vitis\_hls

| 8                        | FJ made neb freteomer ag |              |                      |           |         |
|--------------------------|--------------------------|--------------|----------------------|-----------|---------|
| _⊨<br><mark>64.sh</mark> | Quick Start              | 4            |                      |           | AILIX 3 |
|                          | Create New Project       | Open Project | Open Example Project |           |         |
|                          | Documentation            |              |                      |           |         |
| <mark>sh</mark>          | Tutorials                | User Guide   | Release Notes Guide  |           |         |
|                          |                          |              |                      |           |         |
|                          |                          |              | Marcl                | n 6, 2025 |         |
|                          |                          |              |                      |           |         |

Vivado HLS 2020.1

\lambda Vivado HLS 2020.1 👻

Project Solution Window Help

Vivado HLS Welcome Page 🕱





https://github.com/varuns23/TAC-HEP-FPGA/tree/main/tutorial/wk5lec10

TAC-HEP: GPU & FPGA training module - Varun Sharma

# lec10ex1



| 1  | <pre>#include "lec10ex1.h"</pre>             |
|----|----------------------------------------------|
| 2  |                                              |
| 3  | void lec10ex1 (int $*y$ , int c[N], int x) { |
| 4  |                                              |
| 5  | <pre>static int arr[N];</pre>                |
| 6  | int sum;                                     |
| 7  | int data;                                    |
| 8  | int i;                                       |
| 9  |                                              |
| 10 | sum=0;                                       |
| 11 | Loop:                                        |
| 12 | for (i = N - 1; i >= 0; i)                   |
| 13 | {                                            |
| 14 | if (i == 0)                                  |
| 15 | {                                            |
| 16 | arr[0] = x;                                  |
| 17 | data = $x;$                                  |
| 18 | }                                            |
| 19 | else                                         |
| 20 | {                                            |
| 21 | arr[i] = arr[i - 1];                         |
| 22 | data = arr[i];                               |
| 23 | }                                            |
| 24 | <pre>sum += data * c[i];</pre>               |
| 25 | ;                                            |
| 26 | }                                            |
| 27 | *y = sum;                                    |
| 28 | }                                            |
|    |                                              |

| 1  |        | <pre>#ifndef LEC10EX1_H_</pre> |
|----|--------|--------------------------------|
| 2  |        | <pre>#define LEC10EX1_H_</pre> |
| 3  |        | #define N 11                   |
| 4  |        |                                |
| 5  | $\sim$ | void lec10ex1 (                |
| 6  |        | int ∗y,                        |
| 7  |        | int c[N+1],                    |
| 8  |        | int x                          |
| 9  |        | );                             |
| 10 |        |                                |
| 11 |        | #endif                         |
|    |        |                                |
|    |        |                                |

| 5  | int main()                                                                        |
|----|-----------------------------------------------------------------------------------|
| 6  | {                                                                                 |
| 7  | <pre>const int samples = 600;</pre>                                               |
| 8  | FILE *oFile;                                                                      |
| 9  |                                                                                   |
| 10 | int inp, output;                                                                  |
| 11 | int coef[N] = { 0, -10, -9, 23, 56, 63, 56, 23, -9, -10, 0};                      |
| 12 |                                                                                   |
| 13 | int i, rmp;                                                                       |
| 14 | inp = 0;                                                                          |
| 15 | rmp = 1;                                                                          |
| 16 |                                                                                   |
| 17 | oFile = fopen("lec10ex1_out.dat", "w");                                           |
| 18 | <pre>for (i = 0; i &lt;= samples; i++)</pre>                                      |
| 19 | {                                                                                 |
| 20 | if (rmp == 1)                                                                     |
| 21 | inp = inp + 1;                                                                    |
| 22 | else                                                                              |
| 23 | inp = inp - 1;                                                                    |
| 24 |                                                                                   |
| 25 | <pre>// Execute the function with latest input</pre>                              |
| 26 | <pre>lec10ex1(&amp;output, coef, inp);</pre>                                      |
| 27 |                                                                                   |
| 28 | if ((rmp == 1) && (inp >= 75))                                                    |
| 29 | rmp = 0;                                                                          |
| 30 | else if ((rmp == 0) && (inp <= -75))                                              |
| 31 | rmp = 1;                                                                          |
| 32 |                                                                                   |
| 33 | // Save the results.                                                              |
| 34 | <pre>fprintf(oFile, "%i %d %d\n", i, inp, output);</pre>                          |
| 35 | }                                                                                 |
| 36 | <pre>fclose(oFile);</pre>                                                         |
| 37 |                                                                                   |
| 38 | <pre>printf("Comparing against output data \n");</pre>                            |
| 39 | <pre>if (system("diff -w lec10ex1_out.dat lec10ex1_out_ref.dat"))</pre>           |
| 40 | {                                                                                 |
| 41 |                                                                                   |
| 42 | fprintf(stdout, "************************************                             |
| 43 | <pre>fprintf(stdout, "FAIL: Output DOES NOT match the reference output\n");</pre> |
| 44 | fprintf(stdout, "************************************                             |
| 45 | return 1;                                                                         |
|    |                                                                                   |

TAC-HEP: GPU & FPGA training module - Varun Sharma

March 6, 2025



## Run via CLI

open\_project fir\_proj

set\_top lec10ex1
add\_files lec10ex1.c
add\_files lec10ex1.h
add\_files -tb lec10ex1\_out\_ref.dat
add\_files -tb lec10ex1\_test.c

open\_solution "solution1" set\_part {xcvu9p-flga2104-1-i} create\_clock -period 25 -name default

#source "./fir\_proj/solution1/directives.tcl"

csim\_design
csynth\_design
#cosim\_design
#export\_design -format ip\_catalog
#
#Exit Vivada HLS
exit

Execute: vivado\_hls file.tcl





TAC-HEP: GPU & FPGA training module - Varun Sharma

7

# C – Simulation



| C Simu             | Ilation Dialog        | ×             |
|--------------------|-----------------------|---------------|
| C Simulation       |                       |               |
|                    |                       |               |
| Options            |                       |               |
| Launch Debugger    |                       |               |
| Build Only         |                       |               |
| 🗌 Clean Build      |                       |               |
| Optimizing Compile |                       |               |
| Input Arguments    |                       |               |
|                    | Do not show this dial | og box again. |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    |                       |               |
|                    | Cancel                | ОК            |

Launch Debugger: Compiles the C code & opens the debug perspective

**Build Only:** C code compiles, but the simulation does not run

**Clean Build:** Remove any existing executable and object files from the project before compiling the code

**Optimized Compile:** Uses a higher level of optimization effort when compiling the design but removes all information required by the debugger. This increases the compile time but should reduce the simulation run time

## C – Simulation

•

2025



| Vivado HLS 2020.1 - test (/scratch/varuns/tac-hep-fpga2025/temp/test)     te Edit Project Solution Window Help     Debug Synthesis & Analysis     Splorer B     Implication           Implication </th <th></th> <th>On-going</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | On-going                                                           |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
| Debug A Synthesis & Analysis Explorer 23 P = 0 Source A contained set is a set in the set is a set is a set in the set is a | Viva                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                    |
| Debug Synthesis & Analysis          Explorer & Parling       Image: Comparing against surput data         Image: Comparing against surpu                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | le Edit Project Solution Window I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Help                                                               |
| <pre>Explorer X</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 9 19 19 19 19 19 19 19                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 💩 🖪 🖆 🚳 🍓 🚺 📕 🕨 🔻 🗹 🖶 💼 👘 ▾ 🗏 🕄 🚱                                  |
| <pre>Stest Stest I[NF0: [SIM 2] ***********************************</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 🌾 Debug 🔼 Synthesis & Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | $\mathbf{\vee}$                                                    |
| <pre>2 TNF0: [SIM 4] CSIM will launch GCC as the compiler.<br/>3 make: 'csim.exe' is up to date.<br/>@lec10ex1.c<br/>@lec10ex1.h<br/>@lec10ex1.h<br/>@lec10ex1_est.c<br/>* Solution1<br/>* Constraints<br/>* Solution1<br/>* Constraints<br/>* Solution1<br/>* Constraints<br/>* Solution1<br/>* Constraints<br/>* Solution1<br/>* Solution4<br/>* So</pre>                                                                                            | Explorer 🕱 🔗 🗖 🗖                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 📔 lec10ex1_csim.t 🛛 👔 Synthesis(solut 🎽 " 🗖 🗖 📴 Outli 🕱 🕼 Dire 🗖 🗖 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <pre>Includes Source So</pre> | <pre>i [INFO: [SIM 2] ***********************************</pre>    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                    |

### Finished...

| Viva                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | do HLS 2020.1 - test (/scratch/varuns/tac-hep-fpga2025/temp/test)                      | × |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---|--|
| File Edit Project Solution Window Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                        |   |  |
| 9 R R Z C 🕫 🗈 🗙                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                        |   |  |
| 🕸 Debug 🚺 Synthesis & Analysis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | $\mathbf{\vee}$                                                                        |   |  |
| 🔁 Explorer 🕱 🛛 🤣 🗖 🗖                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 🗈 lec10ex1_csim.l 🕱 👔 Synthesis(solut 🎽 🦈 🦳 🗖 🗖 📴 Outli 🕱 🖉 Dire 🧮                     |   |  |
| <ul> <li>Estest</li> <li>Source</li> <li>control control contr</li></ul> | <pre>1 [NFO: [SIM 2] ***********************************</pre>                         | ~ |  |
| ▼                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 📴 Console 🛱 🔍 Errors 💩 Warnings 🖆 DRCs 🛛 🎼 📓 📴 🖬 🖬 🖉 🗸 🦳                               |   |  |
| lec10ex1_csynth.rpt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Vivado HLS Console                                                                     |   |  |
| <ul> <li>Systemc</li> <li>Control verilog</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | INFO: [SIM 211-1] CSim done with 0 errors.                                             |   |  |
| ► 🗁 vhdl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | INF0: [SIM 211-3] ************** CSIM finish ***************<br>Finished C simulation. |   |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                        |   |  |

# C – simulation output



#### solution1

- constraints
- 🕶 🗁 csim
  - 🔻 🗁 build
    - 📄 apcc.log
    - 🗟 csim.exe
    - 🗟 csim.mk
    - 📄 lec10ex1\_out\_ref.dat
    - 🖹 lec10ex1\_out.dat
    - Makefile.rules
    - 缓 run\_sim.tcl
    - 🕝 sim.sh
    - 🕨 🗁 obj
  - 🕶 🗁 report

lec10ex1\_csim.log

TAC-HEP: GPU & FPGA training module - Varun Sharma

csim/build is the primary location for all files related to the C-simulation

- Any files read by the test bench are copied to this folder
- The C executable file csim.exe is created and run in this folder
- Any files written by the test bench are created in this folder
  - Build Only option: exe file is not executed

Folder csim/report contains a log file of the C simulation

### Next: execute synthesis

Creating an Initial Solution •

Reviewing the Output of C Synthesis ٠

C-Synthesis

- Analyzing the Results of Synthesis •
- Creating a New Solution ٠
- Applying Optimization Directives •

|                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                         | $\mathcal{P}$  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| Viva                                                                                                                                                                                                                                                                                                             | do HLS 2020.1 - test (/scratch/varuns/tac-hep-fpga2025/temp/test)                                                                                                                                                                                                                                                                                                                                       |                |
| File Edit Project Solution Window H                                                                                                                                                                                                                                                                              | łelp                                                                                                                                                                                                                                                                                                                                                                                                    |                |
|                                                                                                                                                                                                                                                                                                                  | 😬 🖪 🕾 🚳 🏶 🔚 🏹 📕 🕶 🕾 📾 🎼 🎜                                                                                                                                                                                                                                                                                                                                                                               |                |
| 🏇 Debug 🔁 Synthesis & Analysis                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                         |                |
| 🔁 Explorer 🕱 🛛 🔗 🗖 🗖                                                                                                                                                                                                                                                                                             | 📄 lec10ex1_csim.l 🕱 📄 lec10ex1_out_re 🛛 🍟 🗖 📴 🔂 🔀 Dire                                                                                                                                                                                                                                                                                                                                                  |                |
| <ul> <li>Source</li> <li>lec10ex1.c</li> <li>lec10ex1.h</li> <li>Test Bench</li> <li>lec10ex1_out_ref.dat</li> <li>lec10ex1_test.c</li> <li>Solution1</li> <li>constraints</li> <li>csim</li> <li>csim</li> <li>csim.exe</li> <li>csim.mk</li> <li>lec10ex1_out_ref.dat</li> <li>lec10ex1_out_ref.dat</li> </ul> | <pre>1 INFO: [SIM 2] ***********************************</pre>                                                                                                                                                                                                                                                                                                                                          | <sup>3</sup> ∇ |
| Makefile.rules                                                                                                                                                                                                                                                                                                   | 🕒 Console 🕱 🧐 Errors 💩 Warnings 🖆 DRCs 🛛 🖳 📓 🖻 📑 🖃 🖉 🖛 🧟                                                                                                                                                                                                                                                                                                                                                |                |
| ∲ run_sim.tcl                                                                                                                                                                                                                                                                                                    | <pre>Vivado HLS Console<br/>INF0: [SYN 201-201] Setting up clock 'default' with a period of 25ns.<br/>INF0: [HLS 200-10] Setting target device to 'xcvu9p-flga2104-1-i'<br/>INF0: [SYN 201-201] Setting up clock 'default' with a period of 25ns.<br/>INF0: [SCHED 204-61] Option 'relax_ii for timing' is enabled, will increase II to<br/>INF0: [HLS 200-10] Analyzing design file 'lec10ex1.c'</pre> | preserv        |
| <u>L</u>                                                                                                                                                                                                                                                                                                         | Vivado HLS Synthesis                                                                                                                                                                                                                                                                                                                                                                                    |                |



March 6, 2025



## Console messages



- During the synthesis process messages are echoed to the console window
- The message include information messages showing how the synthesis process is proceeding

| INF0: | [HLS 200-10]                                                                              |
|-------|-------------------------------------------------------------------------------------------|
|       | [HLS 200-10] Generating RTL for module 'lec10ex1'                                         |
| INF0: | [HLS 200-10]                                                                              |
| INF0: | <pre>[RTGEN 206-500] Setting interface mode on port 'lecl0ex1/y' to 'ap_vld'.</pre>       |
| INF0: | <pre>[RTGEN 206-500] Setting interface mode on port 'lecl0ex1/c' to 'ap_memory'.</pre>    |
| INF0: | <pre>[RTGEN 206-500] Setting interface mode on port 'lecl0ex1/x' to 'ap_none'.</pre>      |
| INF0: | <pre>[RTGEN 206-500] Setting interface mode on function 'lecl0ex1' to 'ap_ctrl_hs'.</pre> |
| INF0: | <pre>[RTGEN 206-100] Finished creating RTL model for 'lec10ex1'.</pre>                    |
| INF0: | [HLS 200-111] Elapsed time: 0.06 seconds; current allocated memory: 138.740 MB.           |
| INF0: | [HLS 200-790] **** Loop Constraint Status: All loop constraints were satisfied.           |
| INF0: | [HLS 200-789] **** Estimated Fmax: 173.25 MHz                                             |

## Console messages

| Debug 📐 Sy                   | Message: RTGEN 206-500                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | , |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| E Console 🕱                  | Message: RTGEN 206-500                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | _ |
|                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |
| Vivado HLS Cor               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| INFO: [HLS 2<br>INFO: [HLS 2 | The top-tever function argument specified in this message has been                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |
| INFO: [SCHED                 | implomented as an U11 port using the specified I() protected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
| INFO: [SCHED                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| INFO: [HLS 2                 | © Explanation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |
| INFO: [BIND                  | 2<br>I UI Channafarma tha annumanta af tha tao Javal function into                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |
| INFO: [BIND<br>INFO: [BIND   | 2 HLS transforms the arguments of the top-level function into                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |   |
| INFO: [BIND                  | corresponding RTL ports with an associated IO protocol. The IO<br>protocol is specified using the mode option of the INTERFACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |
| INFO: [BIND                  | directive. If no interface mode is specified, each type of C argument                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |
| INFO: [HLS 2                 | is implemented with a default IO protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |
| INFO: [HLS 2                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| INFO: [HLS 2<br>INFO: [HLS 2 | The full second has a family low second se |   |
| INFO: [RTGEN                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| INFO: [RTGEN<br>INFO: [HLS 2 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |
| INFO: [HLS 2                 | - write-only scalars and pointers are implemented with the IO protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |
| INFO: [HLS 2                 | ap_vld. With this IO protocol, the function argument is implemented                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |
| INFO: [RTMG                  | as an RTL output data port with an associated valid signal which                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |
| INFO: [HLS 2                 | e                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |
| INFO: [VHDL<br>INFO: [VLOG   | ОК                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |
| INFO: [HLS 2                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | _ |
| Finished C s                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |



Some messages may contain links to enhanced information

Clicking on this message provides more details on why the message was issued and possible resolutions

TAC-HEP: GPU & FPGA training module - Varun Sharma

13





### **Design Rule Checking**

| Console 🕙 Errors 💧 Warnin       | ngs 1 DRCs 🛙                                                                                                                          |
|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
|                                 | ☑ 3 DRC-Infos ☑ 0 DRC-Warnings ☑ 0 DRC-Errors                                                                                         |
|                                 | This info will be updated when the current process completes.                                                                         |
| Name                            | Details                                                                                                                               |
| ✓ THROUGHPUT                    |                                                                                                                                       |
| i [HLS 200-789]<br>▼ ゐ SCHEDULE | **** Estimated Fmax: 173.25 MHz                                                                                                       |
| . ,                             | •••• Estimated Fmax: 173.25 MHz<br>Option 'relax_ii_for_timing' is enabled, will increase II to preserve clock frequency constraints. |

solution1

constraints

# C-Synthesis: Review the output

Folder syn is now available in the solution folder

**report** folder contains a report file for the top-level function

| Csim                   | and one for every sub-function in the design                    |
|------------------------|-----------------------------------------------------------------|
| 🕨 🗁 impl               |                                                                 |
| 🕶 🗁 syn                | verilog, vhdl, and systemc folders contain the output RTL files |
| 🔻 🗁 report             |                                                                 |
| 🗐 lec10ex1_csynth.rpt  | The top-level file has the same name as the top-level function  |
| 🕨 🗁 systemc            | for synthesis                                                   |
| 🔻 🗁 verilog            |                                                                 |
| 📄 lec10ex1_arr_ram.dat | One RTL file for each function                                  |
| RT lec10ex1_arr.v      |                                                                 |
| RT lec10ex1.v          | Might be additional RTL files to implement sub-blocks (block    |
| 🕨 🗁 vhdl               | RAM, pipelined multipliers, etc)                                |
|                        |                                                                 |





- Two primary features provided to analyze the RTL design
  - Synthesis reports
    - The report provides details on both the performance and area of the RTL design
  - Analysis Perspective
    - Analysis Perspective provides both a tabular and graphical view of the design performance and resources and supports cross-referencing between both views

# Synthesis Report

- General Information
  - When results were generated
  - Software version
  - Project name
  - Solution name
  - Technology details

| Date:           | Tue Mar 4 08:04:21 2025                                |
|-----------------|--------------------------------------------------------|
| Version:        | 2020.1 (Build 2897737 on Wed May 27 20:21:37 MDT 2020) |
| Project:        | test                                                   |
| Solution:       | solution1                                              |
| Product family: | virtexuplus                                            |
| Target device:  | xcvu9p-flga2104-1-i                                    |

General Information

- Performance Estimates
- Utilization Estimates
- Interface Summary



# Synthesis Report: Performance Estimates

## Performance Estimates

## Timing:

- Target clock frequency
- Clock uncertainty
- Estimate of the fastest achievable clock

#### Performance Estimates

#### Timing

#### Summary

| ( | Clock | Target   | Estimated | Uncertainty |
|---|-------|----------|-----------|-------------|
| а | p_clk | 25.00 ns | 5.772 ns  | 3.12 ns     |

#### Latency

#### Summary

| Latency | (cycles) | Latency ( | absolute) | Interval | (cycles) |      |
|---------|----------|-----------|-----------|----------|----------|------|
| min     | max      | min       | max       | min      | max      | Туре |
| 34      | 34       | 0.850 us  | 0.850 us  | 34       | 34       | none |

March 6, 2025

Detail

- Instance
- 🗉 Loop



Synthesis Report: Performance Estimates

## Performance Estimates

## Latency (Summary):

- Reports the latency and initiation interval for this block and any sub blocks instantiated in this block
- Each sub function called at this level in the C source is an instance in this RTL block unless it was inlined
- Latency is the number of cycles it takes to produce the output
- Initiation interval is the number of clock cycles before new inputs can be applied
- In the absence of any PIPELINE directives the latency is one cycle less than the initiation interval
- Next input is read when the final output is written

#### Performance Estimates

#### Timing

#### Summary

| Clock | Target   | Estimated | Uncertainty |
|-------|----------|-----------|-------------|
|       | 25.00 ns |           |             |

#### Latency

#### Summary

| Latency | (cycles) | Latency ( | absolute) | Interval | (cycles) |      |
|---------|----------|-----------|-----------|----------|----------|------|
| min     | max      | min       | max       | min      | max      | Туре |
| 34      | 34       | 0.850 us  | 0.850 us  | 34       | 34       | none |

Detail

- Instance
- 🗉 Loop



# Synthesis Report: Performance Estimates

## Performance Estimates

## Latency (Details):

- The latency and initiation interval for the instances sub functions and loops in this block
  - If any loops contain sub loops the loop hierarchy is shown
- The min and max latency values indicate the latency to execute all iterations of the loop.
  - Presence of conditional branches in the code might make the min and max different
- The Iteration Latency is the latency for a single iteration of the loop
- If the loop has a variable latency, the latency values cannot be determined and are shown as a question mark (?)
- Any specified target initiation interval is shown beside the actual initiation interval achieved
- The tripcount shows the total number of loop iterations

#### Latency

#### Summary

| Latency | (cycles) | Latency ( | absolute) | Interval | (cycles) |      |
|---------|----------|-----------|-----------|----------|----------|------|
| min     | max      | min       | max       | min      | max      | Гуре |
| 34      | 34       | 0.850 us  | 0.850 us  | 34       | 341      | none |

Detail

Instance

N/A

#### 🖽 Loop

| Latency (cycles) |     |     |                   |          |        |            |           |
|------------------|-----|-----|-------------------|----------|--------|------------|-----------|
| Loop Name        | min | max | Iteration Latency | achieved | target | Trip Count | Pipelined |
| - Loop           | 33  | 33  | 3                 | -        | -      | 11         | no        |



March 6, 2025

#### 21

# Synthesis Report: Utilization Estimates

## Utilization Estimates:

## Summary

This part of the report shows the resources: LUTS, Flip-Flops, DSPs used to implement the design

#### Utilization Estimates

#### Summary

| Name I            | 3RAM_18K | DSP48E | FF      | LUT     | URAM |
|-------------------|----------|--------|---------|---------|------|
| SP                | -        | -      | -       | -       | -    |
| pression          | -        | 3      | 0       | 85      | -    |
| FO                | -        | -      | -       | -       | -    |
| stance            | -        | -      | -       | -       | -    |
| emory             | 0        | -      | 64      | 6       | 0    |
| ultiplexer        | -        | -      | -       | 105     | -    |
| egister           | -        | -      | 111     | -       | -    |
| otal              | 0        | 3      | 175     | 196     | 0    |
| ailable           | 4320     | 6840   | 2364480 | 1182240 | 960  |
| ailable SLR       | 1440     | 2280   | 788160  | 394080  | 320  |
| ilization (%)     | 0        | ~0     | ~0      | ~0      | 0    |
| ilization SLR (%) | 0        | ~0     | ~0      | ~0      | 0    |
|                   | 0        | -      | -       |         |      |



Synthesis Report: Utilization Estimates

## Utilization Estimates: Details

## Instance:

- The resources specified here are used by the sub blocks instantiated at this level of the hierarchy
- If the design only has no RTL hierarchy there are no instances reported
- If any instances are present clicking on the name of the instance opens the synthesis report for that instance

### Memory

- The resources listed here are those used in the implementation of memories at this level of the hierarchy
- Vivado HLS reports a single port BRAM as using one bank of memory and reports a dual port BRAM as using two banks of memory

## FIFO

• The resources listed here are those used in the implementation of any FIFOs implemented at this level of the hierarchy

| 🗆 Detail           |             |         |           |        |              |
|--------------------|-------------|---------|-----------|--------|--------------|
| Instance           |             |         |           |        |              |
| N/A                |             |         |           |        |              |
| DSP48E             |             |         |           |        |              |
| N/A                |             |         |           |        |              |
| Memory             |             |         |           |        |              |
| Memory Module      | BRAM_18K FF | LUTURAM | WordsBits | BanksV | V*Bits*Banks |
| arr_U lec10ex1_arr | 064         | 6 0     | 11 32     | 2 1    | 352          |
| Total 1            | 064         | 6 0     | 11 32     | 1      | 352          |
| ■ FIFO             |             |         |           |        |              |

N/A

# Synthesis Report: Utilization Estimates

Utilization Estimates: Details

#### Expression:

- Resources used by any expressions such as multipliers adders and comparators at the current level of hierarchy
- Bit widths of the input ports to the expressions are shown

#### Multiplexors:

- Resources used to implement multiplexors at this level of hierarchy
- Input widths of the multiplexors are shown

### Register:

- List of all registers at this level of hierarchy
- The report includes the register bit widths

#### Expression

| Variable Name       | Operation | DSP48E | FF | LUT | Bitwidth P0 | Bitwidth P1 |
|---------------------|-----------|--------|----|-----|-------------|-------------|
| mul_ln24_fu_163_p2  | *         | 3      | 0  | 20  | 32          | 32          |
| grp_fu_125_p2       | +         | 0      | 0  | 15  | 5           | 2           |
| sum_fu_169_p2       | +         | 0      | 0  | 39  | 32          | 32          |
| icmp_ln14_fu_144_p2 | icmp      | 0      | 0  | 11  | 5           | 1           |
| Total               | 4         | 3      | 0  | 85  | 74          | 67          |

#### Multiplexer

| Name           | LUT | Input Size | Bits | Total Bits |
|----------------|-----|------------|------|------------|
| ap_NS_fsm      | 27  | 5          | 1    | 5          |
| arr_address0   | 21  | 4          | 4    | 16         |
| arr_d0         | 15  | 3          | 32   | 96         |
| data_0_reg_116 | 9   | 2          | 32   | 64         |
| grp_fu_125_p0  | 15  | 3          | 5    | 15         |
| i_0_reg_104    | 9   | 2          | 5    | 10         |
| sum_0_reg_91   | 9   | 2          | 32   | 64         |
| Total          | 105 | 21         | 111  | 270        |

#### Register

| Name              | FF  | LUT | Bits | Const Bits |
|-------------------|-----|-----|------|------------|
| ap_CS_fsm         | 4   | 0   | 4    | 0          |
| data_0_reg_116    | 32  | 0   | 32   | 0          |
| i_0_reg_104       | 5   | 0   | 5    | 0          |
| i_reg_209         | 5   | 0   | 5    | 0          |
| icmp_ln14_reg_190 | 1   | 0   | 1    | 0          |
| sext_ln12_reg_181 | 32  | 0   | 32   | 0          |
| sum_0_reg_91      | 32  | 0   | 32   | 0          |
| Total             | 111 | 0   | 111  | 0          |

March 6, 2025



Synthesis Report: Interface Summary

## Interface

- This section shows how the function arguments have been synthesized into RTL ports
- The RTL port names are grouped with their protocol
- **Source object:** RTL ports created when that source object is synthesized with the stated I/O protocol

- The design has a clock and reset port
- Synthesis has automatically added some block level control ports : ap\_start, ap\_done, ap\_idle and ap\_ready

#### Interface

#### Summary

| <b>RTL Ports</b> | Dir | Bits | Protocol   | Source Object | C Type       |
|------------------|-----|------|------------|---------------|--------------|
| ap_clk           | in  | 1    | ap_ctrl_hs | lec10ex1      | return value |
| ap_rst           | in  | 1    | ap_ctrl_hs | lec10ex1      | return value |
| ap_start         | in  | 1    | ap_ctrl_hs | lec10ex1      | return value |
| ap_done          | out | 1    | ap_ctrl_hs | lec10ex1      | return value |
| ap_idle          | out | 1    | ap_ctrl_hs | lec10ex1      | return value |
| ap_ready         | out | 1    | ap_ctrl_hs | lec10ex1      | return value |
| у                | out | 32   | ap_vld     | у             | pointer      |
| y_ap_vld         | out | 1    | ap_vld     | у             | pointer      |
| c_address0       | out | 4    | ap_memory  | c             | array        |
| c_ce0            | out | 1    | ap_memory  | c             | array        |
| c_q0             | in  | 32   | ap_memory  | c             | array        |
| х                | in  | 32   | ap_none    | x             | scalar       |



# Analysis Perspective: Resource view



| 🖹 lec10ex1_csim.l 🛛 🗎 lec10ex1_out.da | a 📄 lec10ex1 | _out_re | 🗊 Synthesis( | solut 🕞 | Resource Vie |
|---------------------------------------|--------------|---------|--------------|---------|--------------|
|                                       |              |         |              |         |              |
| Operation\Control Step                |              | 0       | 1            | 2       | 3            |
| ▼ [+]I/O Ports                        |              |         | -            |         |              |
| x                                     |              | read    |              |         |              |
| У                                     |              |         | write        |         |              |
| c(p0)                                 |              |         |              | re      | ead          |
| <ul> <li>[+]Memory Ports</li> </ul>   |              |         |              |         |              |
| arr(p0)                               |              |         | write        | write   |              |
| c(p0)                                 |              |         |              | re      | ad           |
| ▼ [+]Expressions                      |              |         |              |         |              |
| i_0_phi_fu_108                        |              |         | phí_mux      |         |              |
| sum_0_phi_fu_95                       |              |         | phí_mux      |         |              |
| grp_fu_125                            |              |         | +            | +       |              |
| icmp_ln14_fu_144                      |              |         | ícmp         |         |              |
| data_0_phi_fu_119                     |              |         |              |         | phí_mux      |
| sum_fu_169                            |              |         |              |         | +            |
| mul_ln24_fu_163                       |              |         |              |         | *            |

TAC-HEP: GPU & FPGA training module - Varun Sharma

# Analysis Perspective: Schedule view



| 🗎 lec10ex1_csim.l    | 📄 lec10ex1_out.da | 📄 lec | 10ex1_out_r | e 🗐 Syr  | thesis(solut | 🚍 Schedule Viewer 🛿 |           |  |
|----------------------|-------------------|-------|-------------|----------|--------------|---------------------|-----------|--|
|                      |                   |       |             |          |              | Q Q 30              | Focus Off |  |
| Operation\Control St | tep               | 0     | 1           | 2        | 3            |                     |           |  |
| x_read(read)         | i i               |       | ii 👘        | ii 👘     | li l         | i                   |           |  |
| 🕶 Loop               |                   |       |             | - Loop   | -i-Ji-       |                     |           |  |
| sum_0(phi_mux        | ;)                |       |             | 1        | i i          | 1                   |           |  |
| i_0(phi_mux)         |                   |       |             |          |              |                     |           |  |
| icmp_ln14(icmp       | )                 |       |             |          |              |                     |           |  |
| add_ln21(+)          |                   |       |             | <u> </u> | 11 1         |                     |           |  |
| data(read)           |                   |       |             |          |              |                     |           |  |
| 0_write_ln16(w       | rite)             |       |             |          |              |                     |           |  |
| arr_addr_1_writ      | te_ln:            |       |             |          |              |                     |           |  |
| c_load(read)         |                   |       |             |          |              |                     |           |  |
| i(+)                 |                   |       |             |          |              |                     |           |  |
| data_0(phi_mux       | ()                |       |             | i        | 11 1         |                     |           |  |
| mul_ln24(*)          |                   |       |             |          |              |                     |           |  |
| sum(+)               |                   |       |             |          |              |                     |           |  |
| y_write_ln27(write   | :)                |       |             | !        | 1 1          |                     |           |  |

TAC-HEP: GPU & FPGA training module - Varun Sharma

2025

# Reminder: Assignments

- Assignment-1 (13-02-2025)
- Assignment-2 (18-02-2025)
- Assignment-3 (27-02-2025)

Uploaded to cernbox: <a href="https://cernbox.cern.ch/s/gmUqRDHTxDLqx4M">https://cernbox.cern.ch/s/gmUqRDHTxDLqx4M</a>

Send via email: varun.sharma@cern.ch

Submit in 2 weeks from date of assignment





Acknowledgements:

- Some of these slides are from Isobel Ojalvo

# Jargons



- ICs Integrated chip: assembly of hundreds of millions of transistors on a minor chip
- **PCB:** Printed Circuit Board
- LUT Look Up Table aka 'logic' generic functions on small bitwidth inputs. Combine many to build the algorithm
- FF Flip Flops control the flow of data with the clock pulse. Used to build the pipeline and achieve high throughput
- DSP Digital Signal Processor performs multiplication and other arithmetic in the FPGA
- BRAM Block RAM hardened RAM resource. More efficient memories than using LUTs for more than a few elements
- PCIe or PCI-E Peripheral Component Interconnect Express: is a serial expansion bus standard for connecting a computer to one or more peripheral devices
- InfiniBand is a computer networking communications standard used in high-performance computing that features very high throughput and very low latency
- HLS High Level Synthesis compiler for C, C++, SystemC into FPGA IP cores
- HDL Hardware Description Language low level language for describing circuits
- RTL Register Transfer Level the very low level description of the function and connection of logic gates
- FIFO First In First Out memory
- Latency time between starting processing and receiving the result
  - Measured in clock cycles or seconds
- II Initiation Interval time from accepting first input to accepting next input