When your system is deadlocked, adding FIFOs within the design might help.
In a simple system, you can infer the FIFO sizes from the design and do a manual static
analysis. However, you do not know exactly how many clock cycles are spent in the
main_init()
, the main()
, and the beginning of your kernel
.
The tool computes these FIFO lengths from an AI Engine simulation for you. You can compile
your graph with the AI Engine compiler using the flag --evaluate-fifo-depth
. This option generates infinite FIFOs on all
relevant paths.
Once your code is compiled, run a standard AI Engine simulation with
aiesimulator
. Near the beginning of the simulation you will
get this
warning:[CRITICAL WARNING]: Design was compiled with --evaluate-fifo-depth option, before deploying the design on hardware compile without --evaluate-fifo-depth option.
- Open Vitis Unified IDE and open the simulation
run_summary
. - Note the Estimated FIFO
column, and apply the recommended number of FIFOs using the
fifo_depth
constraint on specific nets.
Figure 1.
Vitis Unified IDE
The estimated FIFO depth are given in the
Estimated FIFO (Words)
column. These values can be used in the graph to
insert FIFOs with the specified length using the following
syntax:fifo_depth(net) = value;
Where
net is a connection on which you want to insert a FIFO.