Hello World ============ This is simple example of vector addition to describe how to use HLS kernels in Vitis Environment. The kernel uses HLS Dataflow which allows the user to schedule multiple task together to achieve higher throughput. **KEY CONCEPTS:** `HLS C Kernel `__, `OpenCL Host APIs `__, `Task Level Parallelism `__ **KEYWORDS:** `gmem `__, `#pragma HLS INTERFACE `__, `m_axi `__, `dataflow `__, `hls::stream `__ This example is a simple hello world example to explain the Host and Kernel code structure. Here a simple ``vadd`` kernel is used to explain the same. The kernel uses HLS Dataflow which allows the user to schedule multiple task together to achieve higher throughput. Vitis kernel can have one s_axilite interface which will be used by host application to configure the kernel. All the global memory access arguments are associated to m_axi(AXI Master Interface) as below: .. code:: cpp #pragma HLS INTERFACE m_axi port = in1 bundle = gmem0 #pragma HLS INTERFACE m_axi port = in2 bundle = gmem1 #pragma HLS INTERFACE m_axi port = out bundle = gmem0 Multiple interfaces can be created based on the requirements. For example when multiple memory accessing arguments need access to global memory simultaneously, user can create multiple master interfaces and can connect to different arguments. Usually data stored in the array is consumed or produced in a sequential manner, a more efficient communication mechanism is to use streaming data as specified by the STREAM pragma, where FIFOs are used instead of RAMs. Vector addition in kernel is divided into 4 sub-tasks(read input 1, read input 2 , compute_add and write) which are then performed concurrently using ``Dataflow``. .. code:: cpp #pragma HLS dataflow load_input(in1, in1_stream, vSize); load_input(in2, in2_stream, vSize); compute_add(in1_stream, in2_stream, out_stream, vSize); store_result(out, out_stream, vSize); EXCLUDED PLATFORMS ------------------ Platforms containing following strings in their names are not supported for this example : :: nodma DESIGN FILES ------------ Application code is located in the src directory. Accelerator binary files will be compiled to the xclbin directory. The xclbin directory is required by the Makefile and its contents will be filled during compilation. A listing of all the files in this example is shown below :: src/host.cpp src/vadd.cpp Access these files in the github repo by `clicking here `__. COMMAND LINE ARGUMENTS ---------------------- Once the environment has been configured, the application can be executed by :: ./hello_world