Create new Project#
Note
In the UltraZohm software, vitis_generate_UltraZohm_workspace.tcl
takes care of this, see Tcl Scripts for more information.
Here you can find a nice tutorial on how to get started with Vitis.
Workspace configuration#
Export the hardware file
data:image/s3,"s3://crabby-images/a4a93/a4a93be3b5db7d8b46c024121f7a1732392852d5" alt="../../../_images/vitis_create1.png"
Define the Vitis workspace
data:image/s3,"s3://crabby-images/caf65/caf653a259f157f6e40639af1ba0beff1acea22a" alt="../../../_images/vitis_create2.png"
Afterwards a file “zusys_wrapper.xsa” will be created which describes the hardware description on the FPGA and includes the Bitstream (in older versions/before vitis/with SDK, this was called “zusys_wrapper.hdf”)
data:image/s3,"s3://crabby-images/64b11/64b119aa9ffb0dd34a0c185f8d78fe3b98bbdacf" alt="../../../_images/vitis_create3.png"
Afterwards we can start Vitis, which was in former days the SDK
data:image/s3,"s3://crabby-images/0e6f4/0e6f4e85caa6f67c6621d5fbbf694de6e5268026" alt="../../../_images/vitis_create4.png"
The Platform Project#
Create a “Platform Project”
data:image/s3,"s3://crabby-images/03a93/03a935b89002681efbb0f2c2f14faf9b73b447ac" alt="../../../_images/vitis_create5.png"
data:image/s3,"s3://crabby-images/bbad8/bbad8d8953a4fcbb023ca1ebec956e7258a66d49" alt="../../../_images/vitis_create6.png"
data:image/s3,"s3://crabby-images/a4732/a473297f3ac69966fac901ed9746c4ddb73ca61f" alt="../../../_images/vitis_create7.png"
data:image/s3,"s3://crabby-images/eddb9/eddb97a047474867ebb672df7cee1bed5a539a7c" alt="../../../_images/vitis_create8.png"
Activate the creation of a Boot Image
data:image/s3,"s3://crabby-images/6e4e1/6e4e1478e97e68c9b7176253d061886834c00d5d" alt="../../../_images/vitis_create9.png"
Afterwards, you have the Platform project ready. You have to do this only once.
data:image/s3,"s3://crabby-images/bca9b/bca9b7e348d34c6d0dc32189c413da5e9f6cc97e" alt="../../../_images/vitis_create10.png"
Add the LW-IP-Ethernet IP-Core
Right click on the FreeRTOS BSP
Modify BSP settings
Add the IP-Core
Build the platform especially if the platform is “out-of-date”
data:image/s3,"s3://crabby-images/a2a04/a2a04cb7b48e80f88b9d89e26e1d1258f24053e8" alt="../../../_images/vitis_create13.png"
The Application Project#
Next step will be to create an “Application Project” for each different solution.
FreeRTOS#
In our case we have one processor of the A53 for the FreeRTOS:
data:image/s3,"s3://crabby-images/dfe35/dfe35f18967749b21dc31fbbe74d2895503fc38a" alt="../../../_images/vitis_create14.png"
data:image/s3,"s3://crabby-images/c4b9f/c4b9fef926b3c8d4b98ee75b0187cb9065bab907" alt="../../../_images/vitis_create15.png"
data:image/s3,"s3://crabby-images/a0e5f/a0e5f247ebda227b32c5622aae077a12888ec9d9" alt="../../../_images/vitis_create16.png"
If the necessary Platform is not shown, press the “+” and select the “ProjectName.xpfm” file from the path manually.
data:image/s3,"s3://crabby-images/1d701/1d7017e4340bf80ce6f0f5b6805c45a5cc08c8ce" alt="../../../_images/vitis_create17.png"
The following step works only if the LW-IP was included before:
data:image/s3,"s3://crabby-images/fec75/fec75d1fd8a140fdc32aad44a4d94dfdfa426de3" alt="../../../_images/vitis_create18.png"
Press Finish
data:image/s3,"s3://crabby-images/e4097/e40974f20edfc43285303f19c813f22d4aaee88e" alt="../../../_images/vitis_create19.png"
You will see the name of the “Platform Project”, on which the “Application Project” is based on, in the yellow brackets behind the application.
Bare Metal#
We will use one processor of the R5 for the Bare Metal application
Since during creation of the “platform Design” we just created a “System project” for the A53_0, we now have to do the same manually for the R5
Right click on the “Vitis_UltraZohm” and add a domain
data:image/s3,"s3://crabby-images/9880a/9880ad1bed4bc7ec151728ea314d3061eb9ee86d" alt="../../../_images/vitis_create20.png"
data:image/s3,"s3://crabby-images/79090/79090610fddd637ba200dc120870fc29e158e20b" alt="../../../_images/vitis_create21.png"
You should see the domain now. Rename the FreeRTOS to just freertos
data:image/s3,"s3://crabby-images/b3dc2/b3dc23c5139165797768ad160660d99ce592c821" alt="../../../_images/vitis_create22.png"
Rebuild the platform project since it is out-of-date (yellow comment)
Add the new application project.
data:image/s3,"s3://crabby-images/e31d0/e31d0c94a87fbad74303c27c8742b61ebcd544a3" alt="../../../_images/vitis_create23.png"
Side comment: If there is already another Platform and Application present in VITIS, it may happen, that the new domain is not visible. In this case, it is necessary to delete the old/other Platform and Application. Afterwards, the new domain, e.g. for BareMetal is visible.
data:image/s3,"s3://crabby-images/ad17e/ad17e996f0e8345dc8fe1b10ecb84277fe60eee9" alt="../../../_images/vitis_create24.png"
data:image/s3,"s3://crabby-images/3b390/3b390bfd0c8b3764d5f468fac76c43fdc43fc293" alt="../../../_images/vitis_create25.png"
C-Project Setup#
The project structure should be ready at this time.
Include the source (.c) and header (.h) files
data:image/s3,"s3://crabby-images/9c33c/9c33c79858caf7d764017237486e18f8cddb5667" alt="../../../_images/vitis_create26.png"
Make sure that the UltraZohm linker script is included.
data:image/s3,"s3://crabby-images/f38bc/f38bc04b6aa449e346d13776f9623ab13ea7cb84" alt="../../../_images/vitis_create27.png"
At this moment the system is ready for modifications
data:image/s3,"s3://crabby-images/4e082/4e082f59d9d887b808a24636e8840877dc1a6e70" alt="../../../_images/vitis_create28.png"
You can start a debug session now
data:image/s3,"s3://crabby-images/5c22f/5c22fac4663074bcde8cb49f37a6519909a55a13" alt="../../../_images/vitis_create29.png"