Optimizations in Vitis HLS
In the AMD Vitis™
software platform, a kernel
defined in the C/C++ language must be compiled into the register transfer level (RTL) that can
be implemented into the programmable logic of an AMD
device. The v++
compiler calls the Vitis High-Level Synthesis (HLS) tool to synthesize the RTL code from the kernel
source code.
The HLS tool is intended to work with the Vitis IDE project without interaction. However, the HLS tool also provides pragmas that can be used to optimize the design, reduce latency, improve throughput performance, and reduce area and device resource usage of the resulting RTL code. These pragmas can be added directly to the source code for the kernel.
The HLS pragmas include the optimization types specified in the following table.
For detailed pragma information, refer to the Vitis High-Level Synthesis User Guide (UG1399).
Type | Attributes |
---|---|
Kernel Optimization | |
Function Inlining | |
Interface Synthesis | |
Task-level Pipeline | |
Pipeline | |
Loop Unrolling | |
Loop Optimization | |
Array Optimization | |
Structure Packing |