See Vitis™ Development Environment on xilinx.com |
Version: Vitis 2023.2 and Vivado 2023.2
In this module, you will create a custom Vitis embedded platform for ZCU104 capable of running Vitis acceleration applications. Additionally, this platform is versatile enough to support general embedded software applications. The diagram below illustrates the structure of this example system.
Since ZCU104 is a validated AMD Evaluation Board and the AMD Vivado™ Design Suite includes its processing system presets, you can skip validating the board and start to build the full hardware and generate XSA.
To prepare the software components, follow these steps:
- Use the common image and create the DTB file according to the XSA file exported from step1.
- Package the platform.
- Run several test applications including Vitis AI applications on this customized platform to test it.
The platform should be able to run the following applications:
- Vitis acceleration examples like Vector Addition
- Vitis AI applications
Vadd application requires 1x clock, 1x interrupt, 1x M_AXI for kernel control, and 1x S_AXI for memory access.
On the software side, the platform should provide XRT and ZOCL packages. The host application can use the XRT OpenCL API to control the kernel. ZOCL is the kernel module that communicates with acceleration kernels. It needs a device tree node, so it should be added. The common image provided by AMD is loaded with these features. Besides these common features, you can also add GCC compilers for application native compilation. Additionally, you can replace the dropbear with openssh so that the network speed can be faster.
The following sections will introduce the platform creation steps. Each section describes one major step in the platform creation process.
-
Step 1: Create the Hardware Platform
Use Vivado tools to generate an XSA file which contains the hardware information for the platform -
Step 2: Create the Vitis Software Platform
Prepare software components and create the Vitis platform -
Step 3: Create Vitis Application
Create a simple application to validate the Vitis platform -
Iteration Guidelines
Iteration steps and guidelines
Start from step 1: Create the Hardware Platform.
- Vitis Unified IDE becomes the default IDE.
createdts
add user's device tree file support
- From this version, the pre-built Linux common image is used instead of building Linux components with PetaLinux because the pre-built common image provides the most common features for Vitis acceleration and it can help expedite the platform creation process. If you wish to leverage the PetaLinux tool to customize your system, refer to the PetaLinux Customization Tutorial.
- Simplify the device tree generation flow by using the newly introduced
createdts
XSCT command.
- The Vivado project exports the XSA for hardware and hardware emulation separately. When creating the platform in step3, it is recommended that you provide separate XSA for hardware and hardware emulation.
- UG1393: Vitis Acceleration Flow User Guide
- Platform Examples
- zcu102 and zcu104 base platform source code in Vitis Embedded Platform Source Github Repository
- Vitis AI Github Repository
Copyright © 2020–2023 Advanced Micro Devices, Inc