Skip to content

Latest commit

 

History

History

Vitis_Platform

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Vitis™ Getting Started Tutorials

See Vitis™ Development Environment on amd.com

Versal Platform Creation Quick Start

Vitis Unified IDE 2024.2, Vivado 2024.2

Board: VCK190 VEK280

In this module, we will get started with three steps to quickly create a platform and run applications to validate this platform based on VCK190 or VEK280 evaluation board in short.

This time, we will utilize the AMD Versal™ extensible platform from the CED example, using a pre-built Linux common image and a device tree file generated with the Platform Creation. Next, we will create an embedded Versal acceleration platform using the AMD Vitis™ Unified IDE. Finally, we will validate this platform using the Vector Addition example.

This is a quick start guide for Versal platform creation. If you have questions about specific steps or settings, or if you need to create a platform for a customer's board, please refer toVersal Custom Platform Creation Tutorial. Besides, if you need to customize the Linux system image, refer to the PetaLinux customization page for reference.

Step 1: Create Vivado Design and Generate XSA

  1. Create a workspace and launch AMD Vivado™

    • mkdir WorkSpace
    • cd WorkSpace
    • Run source <Vitis_Install_Directory>/settings64.sh to setup Vivado running environment
    • Run Vivado by typing vivado in the console.
  2. Download the Versal Extensible Embedded Platform Example

    • Click menu Tools -> Vivado Store.
    • Click OK to agree to download open source examples from web.
    • Select Platform -> Versal Extensible Embedded Platform and click the download button on the tool bar.
    • Click Close after installation complete.

    Vivado XHUB download examples

    Note: You can click Refresh to download the latest version.

  3. Create the Versal Extensible Embedded Platform Example project

    • Click File -> Project -> Open Example.

    • Click Next.

    • Select Versal Extensible Embedded Platform in Select Project Template window.

    • Input project name and project location. Keep Create project subdirectory checked. Click Next.

    • Select target board in Default Part window. In this example, we use Versal VCK190 Evaluation Platform. Click Next.

      Note: Please select Versal VEK280 Pre-production board if you target vek280.

    CED Configuration

    • Configure Clocks Settings. You can enable more clocks, update output frequency and define default clock in this view. In this example, we can keep the default settings.
    • Block Design COntainer(BDC) is to support Vitis Export to Vivdao flow. User could enable it accordingly. In this example, keep it disabled.
    • Configure AXI master and Interrupt Settings. You can choose how many interrupt and AXI masters this platform should support. 63 interrupts modes use two AXI_INTC in cascade mode. In this example, we can keep the default setting.
    • Enbale BDC or not. Block container design is to support Vitis export to vivado flow. You can enbale it according to your project. In this example, we keep the default setting.
    • Enable the AI engine according to your requirement. In this example, we can keep the default setting.
    • Click Next.
    • Review the new project summary and click Finish.
    • After a while, the design example is generated.

    The generated design is shown in the following figure:

    Vivado Design Block Diagram

    At this stage, the Vivado block automation has added a Control, Interface & Processing System (shorten with CIPS in the future) block, AXI NOC block, AI Engine, and all supporting logic blocks to the diagram, and applied all board presets for the VCK190 or VEK280.

    Note: The block design of the VEk280 is slightly different from that of the VCK190. While the VCK190 incorporates one DDR4 and one LPDDR4, the VEK280 elevates its performance with the inclusion of two LPDDR4s.

  4. Generate Block Diagram

    • Click Generate Block Diagram from the Flow Navigator window.

    missing image

    • Select Synthesis Options to Global to save generation time.

    missing image

    • Click Generate button.

    Note: It is safe to ignore this critical warning. Vitis will connect this signal in the future.

    Intr Critical Warning

  5. Export hardware platform with the following scripts:

    • Click File -> Export -> Export Platform. Alternative ways are: Flow Navigator window: IP Integrator -> Export Platform, or the Export Platform button on the bottom of Platform Setup tab.
    • Click Next on Export Hardware Platform page.
    • Select Hardware and hardware emulation. Click Next.
    • Select Pre-synthesis, because we are not making an DFX platform. Click Next.
    • Input Name: Custom_Platform, click Next.
    • Update file XSA file name to vck190_custom, click Next.
    • Review the summary. Click Finish.
    • vck190_custom.xsa file is generated in Vivado project location directory.

    Note: If there are any IPs that do not support simulation, generate Hardware XSA and Hardware Emulation XSA separately.

    Note: If you target VEK280, please update XSA name to vek280_custom.

Step 2: Create Vitis Platform

  1. Download Versal common image from AMD website download page, place it under your WorkSpace directory, and extract the common image.

    tar xvf ../xilinx-versal-common-v2024.2.tar.gz .
  2. Create Vitis platform

    • Install SDK tool by typing sh xilinx-versal-common-v2024.2/sdk.sh -d xilinx-versal-common-v2024.2/ -y in console. Option -d is to specify the directory where to install. Option -y means confirmation. So it gets installed in xilinx-versal-common-v2024.2/ folder.

    Note: The SDK installation is not required for platform creation; it is needed for application compilation. You can install it later as needed.

    • Run Vitis by typing vitis -w . in the console. -w is to specify the workspace. . means the current workspace.

    • In the Vitis IDE, select File > New Component > Platform to create a platform component.

    • Enter the Component name. For this example, type vck190_custom, click Next.

      Note: If you target VEK280, please update component name to vek280_custom.

    • In the XSA selecting page, click Browse button, select the XSA file generated by the Vivado. In this case, it is Your Vivado Project Directory>/vck190_custom.xsa or vek280_custom.xsa. Expand the Advanced Options and set the items as following:

    Created Vitis Platform

    • SDT Source Repo: This is used to replace the built-in SDT tool. For this tutorial, leave it empty.

    • Board DTSI: Specify the board machine name, which is used to retrieve the board-level DTSI file. For this tutorial, leave it empty. To check the board machine name, refer to UG1144 Machine Name Checking

    • User DTSI: Allows you to specify a custom DTSI file. Click Browse and select the the system-suer.dtsi file located in the corresponding board folder.

    • DT ZOCL: Enables Zocl node generation for the XRT driver. Ensure this option is enabled, then click Next.

    • Set the Operating System to Linux and the Processor to psv_cortexa72. Enable the Generate Device Tree Blob (DTB) option, then click Next.

    • Review the summary and click Finish.

    Created Vitis Platform

    • Click the linux On psv_cortexa72 domain.

    • Update the Display Name to xrt by clicking the entry bar and inputting the name. It is indicated that this is a Linux domain has XRT installed and can run acceleration applications.

    • Set Bif file: Click the button as shown in the following diagram and generate BIF file. The BIF file is generated in the resource directory.

      vitis_platform_config

    • Pre-Built Image Directory: Browse to extracted common image path directory: xilinx-versal-common-v2024.2/ and click OK. Bootgen looks for boot components referred by BIF in this directory to generate BOOT.BIN.

    • DTB file: It will be generated automatically and populated in this area.

    • FAT32 Partition Directory: if you have additional file to be stored in FAT32 partition diretory you can browse to the file. If not please omit this.

    • QEMU Data: This Directory is used to add additional file for emulation. User can set it according to your requirement.

    • In the flow navigator, click the drop-down button to select the component. In this case, select vck190_custom component and click the Build button to build the platform.

    Note: If there are additional QEMU settings, update qemu_args.txt accordingly.

    After this step2, the platform creation process is completed. Next, run an application to validate this platform.

Step 3: Validate this Vitis PLatform

  • Run Vitis by typing vitis -w . in the console (If you have launched Vitis, omit this step).
  • In the view, Click Example button and expand the Installed Examples Repository directory like the following:

missing image

  • Select Simple Vector Addition, and click Create application from template.

  • Input the System project name: vadd and click Next.

  • Select the platform we created in previous step. In this case, it is vck190_custom platform.

    Note: If you target VEK280, please select vek280_custom platform.

  • Input Sysroot path: xilinx-versal-common-v2024.2/sysroots/cortexa72-cortexa53-xilinx-linux

  • Input RootFS path: xilinx-versal-common-v2024.2/rootfs.ext4

  • Input Kernel Image path: xilinx-versal-common-v2024.2/Image and click Next.

  • Review the project summary and click Finish.

After seconds, the project is created. missing image

  • Select Component vadd in flow navigator. Click Build all under HARDWARE target. A window pops up prompting to choose which modules to compile. Select all and click OK.

missing image

  • It takes some time to build hardware. Finally, Vitis generates sd_card.img in vadd/build/hw/package/package/ directory.

Run the Application on Hardware

  1. Copy vadd/build/hw/package/package/sd_card.img to local if you build the project on a remote server or virtual machine.

  2. Program sd_card.img to SD card. Refer to AR#73711 for detailed steps.

    Note: Eject the SD card properly from the system after programming it.

  3. Connect to UART console.

  4. Insert the SD card and boot the VCK190 board with SD boot mode (SW1[4:1] = "1110": OFF, OFF, OFF, ON) and power on.

    Note: Refer to VCK190 Evaluation Board User Guide for details about boot mode.

  5. Launch the test application from UART console.

    Follow below steps to run the application

    Login with user petalinux first and setup a new password (it is then also the sudo password):

    • Log into the system
    petalinux login:petalinux
    You are required to change your password immediately (administrator enforced).
    New password:
    Retype new password:
    petalinux:~$ sudo su
    We trust you have received the usual lecture from the local System
    Administrator. It usually boils down to these three things:
        #1) Respect the privacy of others.
        #2) Think before you type.
        #3) With great power comes great responsibility.
    Password:
    petalinux:/home/petalinux#
    • Go to auto mounted FAT32 partition and run the application as shown below:
    petalinux:/home/petalinux# cd /run/media/sd-mmcblk0p1
    petalinux:/home/petalinux# ./simple_vadd krnl_vadd.xclbin
    
  6. Expected print on UART console.

Show Log
root@petalinux:/run/media/mmcblk0p1# ./vadd binary_container_1.xclbin
EXE: /run/media/mmcblk0p1/simple_vadd
[XRT] WARNING: The xrt.ini flag "opencl_summary" is deprecated and will be removed in a future release.  A summary file is generated when when any profiling is enabled, so please use the appropriate settings from "opencl_trace=true", "device_counter=true", and "device_trace=true."
[XRT] WARNING: The xrt.ini flag "opencl_device_counter" is deprecated and will be removed in a future release.  Please use the equivalent flag "device_counter."
INFO: Reading krnl_vadd.xclbin
Loading: 'krnl_vadd.xclbin'
[   74.394840] zocl-drm amba_pl@0:zyxclmm_drm: zocl_create_client: created KDS client for pid(577), ret: 0
[   74.395731] zocl-drm amba_pl@0:zyxclmm_drm: zocl_destroy_client: client exits pid(577)
[   74.401000] zocl-drm amba_pl@0:zyxclmm_drm: zocl_create_client: created KDS client for pid(577), ret: 0
Trying to program device[0]: edge
[   74.937477] [drm] skip kind 29(AIE_RESOURCES) return code: -22
[   74.938038] [drm] found kind 8(IP_LAYOUT)
[   74.938641] [drm] found kind 9(DEBUG_IP_LAYOUT)
[   74.939375] [drm] skip kind 25(AIE_METADATA) return code: -22
[   74.939688] [drm] found kind 7(CONNECTIVITY)
[   74.940087] [drm] found kind 6(MEM_TOPOLOGY)
[   74.940907] [drm] Memory 0 is not reserved in device tree. Will allocate memory from CMA
[   74.948647] [drm] Memory 1 is not reserved in device tree. Will allocate memory from CMA
[   74.963753] cu_drv CU.2.auto: cu_probe: CU[0] created
[   74.974174] cu_drv CU.2.auto:  ffff000803cbac10 xrt_cu_intr_thread: CU[0] start
[   74.989334] [drm] zocl_xclbin_read_axlf f4f049d5-183a-e265-264d-ecfa34a51343 ret: 0
[   75.037345] [drm] bitstream f4f049d5-183a-e265-264d-ecfa34a51343 locked, ref=1
[   75.038188] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_add_context: Client pid(577) add context CU(0xffffffff) shared(true)
[   75.041054] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_del_context: Client pid(577) del context CU(0xffffffff)
[   75.042096] [drm] bitstream f4f049d5-183a-e265-264d-ecfa34a51343 unlocked, ref=0
[   75.094803] [drm] bitstream f4f049d5-183a-e265-264d-ecfa34a51343 locked, ref=1
[   75.095393] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_add_context: Client pid(577) add context CU(0xffffffff) shared(true)
Device[0]: program successful!
[   75.188269] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_add_context: Client pid(577) add context CU(0xffffffff) shared(true)
[   75.192218] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_add_context: Client pid(577) add context CU(0x0) shared(true)
TEST PASSED
[   78.347703] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_del_context: Client pid(577) del context CU(0xffffffff)
[   78.349191] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_del_context: Client pid(577) del context CU(0x0)
[   78.354584] zocl-drm amba_pl@0:zyxclmm_drm:  ffff000800323c10 kds_del_context: Client pid(577) del context CU(0xffffffff)
[   78.355356] [drm] bitstream f4f049d5-183a-e265-264d-ecfa34a51343 unlocked, ref=0
[   78.462912] zocl-drm amba_pl@0:zyxclmm_drm: zocl_destroy_client: client exits pid(577)

Fast Track

Scripts are provided to package and test the Vitis platform.

To use these scripts, download Versal common image from AMD website download page and give its path to the following command.

  1. Run build

    # cd to the ref_files directory, e.g.
    cd ref_files/<board>
    make all COMMON_IMAGE_VERSAL=<path/to/common_image/>  #Specify the path of the common image

    This command is to generate platform with pre-built software components and do sw emulation by running vadd application to test this platform.

    make sd_card COMMON_IMAGE_VERSAL=<path/to/common_image/>  #Specify the path of the common image
    

    This command is to generate platform with pre-built software components and do hw test on board by running vadd application to test this platform.

  2. To clean the generated files, run

    make clean

Copyright © 2020–2024 Advanced Micro Devices, Inc

Terms and Conditions