data:image/s3,"s3://crabby-images/60bb0/60bb02db0f3cb2db0f508e103cbfe5256e96e9a8" alt=""
This post demonstrates how to create and debug a ZCU102 FSBL and FSBL BSP using Xilinx's 2019.2 Vitis, previously known as the Xilinx SDK.
Create an FSBL
#1 Run Vitis IDE 2019.2
#2 Set Workspace: to /home/demo/demobspdebug and click Launch
#3 Click the x to close the Welcome screen:
data:image/s3,"s3://crabby-images/437b4/437b492e029cc30dc9b4733999608d8c7e75ca8f" alt=""
#4 Create an Application Project…
data:image/s3,"s3://crabby-images/5e66a/5e66a0093dd8152fa420a6721925c09eceb86474" alt=""
#5 Use debugfsblbsp for Project name: , accept defaults, and click Next >
data:image/s3,"s3://crabby-images/6246d/6246d725477d71911496e6644e97630855cfb621" alt=""
#6 Click on the Create a new platform from hardware (XSA), select zcu102, click Next >
data:image/s3,"s3://crabby-images/e8c49/e8c4904f660286ed54990e7ac54e3e2229dea643" alt=""
#7 Click Next >
data:image/s3,"s3://crabby-images/0c1b5/0c1b51953a79c687dc403b737e29e75b156557ee" alt=""
#8 Select Zynq MP FSBL and click Finish
data:image/s3,"s3://crabby-images/74317/743173ac997628eb26bbf2323def6aa196c33228" alt=""
Note: we have two FSBLs:
What we're working on:
/home/demo/demobspdebug/debugfsblbsp/src
Part of the "platform" which we don't use:
/home/demo/demobspdebug/zcu102/zynqmp_fsbl
#9 Build the FSBL "app" and BSP. Click on debugfsblbsp_system [zcu102] and click the hammer icon to build
data:image/s3,"s3://crabby-images/4121f/4121f10de0af311172447c1792fa7272d8191229" alt=""
Note: High-level progress is listed in the bottom left corner of the GUI:
data:image/s3,"s3://crabby-images/5a76f/5a76f6fc370a2be32e305a833f4cade210a8ca91" alt=""
Note 2:
You can switch between consoles here:
data:image/s3,"s3://crabby-images/68f5a/68f5add94d2fd807f3707c14b2197a3a189b34d6" alt=""
CDT Global Build Console
Contains all the build output
Output from this post: https://drive.google.com/file/d/1WnPVOeIhAaxuCrj3brqT8edOs-mjoedL/view?usp=sharing
Platform Tcl Console
Contains the TCL commands used to create the platform(s)
Output from this post: https://drive.google.com/file/d/1WqDV2ScxiYO3Xl6wfav4vJCh1ni3LBQ9/view?usp=sharing
Build Console [debugfsblbsp_system, Debug]
Contains "system" level commands, in this case the command that creates a BOOT.BIN using a BIF
Output from this post: https://drive.google.com/file/d/1WqOUhMh3pG2m1p0hdJJ5rUBMFNqZZZJz/view?usp=sharing
Build Console [debugfsblbsp, Debug]
Contains the build output from the FSBL we're building (not the one under zcu102)
Output from this post: https://drive.google.com/file/d/1WsBNmWF0FhChRt_xszzC6VxOKyfriwk4/view?usp=sharing
Build Console [zcu102]
Contains the build output from the BSP build.
Output from the post: https://drive.google.com/file/d/1X-qXkF3p3iY45H90CGmLKs-3avCMHXrB/view?usp=sharing
Debug the Created FSBL
#1 Test. Right-click on debugfsblbsp, hover over Debug As, and click Launch on Hardware (System Project Debug)
data:image/s3,"s3://crabby-images/b8a55/b8a55c998be2c325786892edc749bce91c4ecd86" alt=""
You should see:
data:image/s3,"s3://crabby-images/635db/635dbd79429df408a62bc1c64dbd3cf7a978b166" alt=""
#2 Update the debug configuration to point to the FSBL we're working on. Click the down arrow by the bug icon and select Debug Configurations…
data:image/s3,"s3://crabby-images/1e3bb/1e3bbb8649ab6bd1ee793538f6c17ebc531a8f2b" alt=""
#3 Expand System Project Debug, click on SystemDebugger_debugfsblbsp_system, click on Target Setup, deselect Run psu_init, and deselect Use FSBL flow for initialization.
data:image/s3,"s3://crabby-images/61185/61185a95ed5dd7f96ad217d6f425cf38fe9fd01a" alt=""
#4 Click Apply and click Debug
data:image/s3,"s3://crabby-images/f0a26/f0a260ff18f316b82237f26f639825d9f2db0837" alt=""
Note: changing the Target Setup is needed because running the FSBL twice, runs the psu_init twice, which causes problems. psu_init is a bunch of generated code that actually "connects" the Vivado output to the embedded platform output.
You should see the FSBL we're debugging downloaded:
data:image/s3,"s3://crabby-images/6c5da/6c5da06eb58ae6a5af6d383736304d7f06759d38" alt=""
#5 Look at the console output. Type:
screen /dev/ttyUSB0 115200
Note:
Ctrl-a d to detach screen -r to reattach:
You should see:
Xilinx Zynq MP First Stage Boot Loader
Release 2019.2 Dec 3 2021 - 15:41:27
PMU-FW is not running, certain applications may not be supported.
(A) Click Design, (B) click xfsbl_main.c, (C) Add a "My" to the string, (D) click build, and (E) click debug
data:image/s3,"s3://crabby-images/b9ef2/b9ef2ee7ab48c17f95c042576b798740d69a7f61" alt=""
You should see the following on your terminal:
My Xilinx Zynq MP First Stage Boot Loader
Release 2019.2 Dec 3 2021 - 16:46:24
PMU-FW is not running, certain applications may not be supported.
Enable FSBL Debug Symbols (and Fix Error)
#1 Enable debug symbols in the FSBL.
(A) Click Design, (B) right-click on debugfsblbsp [standalone on psu_cortexa53_0], (C) click C/C++ Build Settings
data:image/s3,"s3://crabby-images/e0805/e08052aab1b450495d505cf0f942101981f4beeb" alt=""
#2 Click C/C++ Build > Settings and click Miscellaneous
data:image/s3,"s3://crabby-images/0ccc9/0ccc912be9b0125d6bbcf74c4bbf102eb54e2508" alt=""
#3 Change:
-Os -flto -ffat-lto-objects
to
-O1
…and click Apply
…and click Apply and Close
data:image/s3,"s3://crabby-images/bfd6e/bfd6ea34d2ce1aae2a7c82dd9e400bb4f7db051d" alt=""
You'll see errors:
data:image/s3,"s3://crabby-images/d74c7/d74c794bf51d94f2cf1d04d0d8899fbd80987d03" alt=""
Console output from this post: https://drive.google.com/file/d/1XAjRiuaPisCuMg9tSzaRu66mgRulBLzj/view?usp=sharing
#4 Fix errors. (A) Open xfsbl_config.h and...
data:image/s3,"s3://crabby-images/1fed3/1fed3274c6e506c7b82911cb7c40c74f0e6da98d" alt=""
(B) set all of these from:
#define FSBL_NAND_EXCLUDE_VAL (0U)
#define FSBL_QSPI_EXCLUDE_VAL (0U)
#define FSBL_SD_EXCLUDE_VAL (0U)
#define FSBL_SECURE_EXCLUDE_VAL (0U)
#define FSBL_BS_EXCLUDE_VAL (0U)
#define FSBL_EARLY_HANDOFF_EXCLUDE_VAL (1U)
#define FSBL_WDT_EXCLUDE_VAL (0U)
#define FSBL_PERF_EXCLUDE_VAL (1U)
#define FSBL_A53_TCM_ECC_EXCLUDE_VAL (1U)
#define FSBL_PL_CLEAR_EXCLUDE_VAL (1U)
#define FSBL_USB_EXCLUDE_VAL (1U)
#define FSBL_PROT_BYPASS_EXCLUDE_VAL (1U)
#define FSBL_PARTITION_LOAD_EXCLUDE_VAL (0U)
#define FSBL_FORCE_ENC_EXCLUDE_VAL (0U)
#define FSBL_DDR_SR_EXCLUDE_VAL (1U)
…to (all 1U):
#define FSBL_NAND_EXCLUDE_VAL (1U)
#define FSBL_QSPI_EXCLUDE_VAL (1U)
#define FSBL_SD_EXCLUDE_VAL (1U)
#define FSBL_SECURE_EXCLUDE_VAL (1U)
#define FSBL_BS_EXCLUDE_VAL (1U)
#define FSBL_EARLY_HANDOFF_EXCLUDE_VAL (1U)
#define FSBL_WDT_EXCLUDE_VAL (1U)
#define FSBL_PERF_EXCLUDE_VAL (1U)
#define FSBL_A53_TCM_ECC_EXCLUDE_VAL (1U)
#define FSBL_PL_CLEAR_EXCLUDE_VAL (1U)
#define FSBL_USB_EXCLUDE_VAL (1U)
#define FSBL_PROT_BYPASS_EXCLUDE_VAL (1U)
#define FSBL_PARTITION_LOAD_EXCLUDE_VAL (1U)
#define FSBL_FORCE_ENC_EXCLUDE_VAL (1U)
#define FSBL_DDR_SR_EXCLUDE_VAL (1U)
#5 Click Save All and click Build
data:image/s3,"s3://crabby-images/7cd69/7cd694fa38368b9410302dbb41e21ddaf3607351" alt=""
You should see:
data:image/s3,"s3://crabby-images/818b4/818b4c0ffdf042e257b320e70aa06440a756d87d" alt=""
Console output from this post: https://drive.google.com/file/d/1XB9Jo_aD9WQqxIvL33qEgGKvQe_q8kxV/view?usp=sharing
#6 Click Debug
data:image/s3,"s3://crabby-images/8fd46/8fd46bbaabf697a610824cbb3dd2115035e2d9ac" alt=""
You should see source-level debug working:
data:image/s3,"s3://crabby-images/e8633/e863316f32231316c5104c59af78afe9ae53692c" alt=""
Enable Debug Symbols in the FSBL's BSP
#1 Enable symbols in the BSP
(A) Click Design
(B) Find and double-click the BSP's Makefile
(C) Scroll over the editor
(D) Find:
-Os -flto -ffat-lto-objects
data:image/s3,"s3://crabby-images/3ad58/3ad58880d84e51f07f43acb2ae82952504837ad8" alt=""
(A) Change:
-Os -flto -ffat-lto-objects
…to
-O1
(B) Click Save All
(C) Click Build
data:image/s3,"s3://crabby-images/c25bf/c25bf81d5d647e639b80aa7dd8292c5613d7b9b9" alt=""
You should see the correct flags in the BSP Build Console
data:image/s3,"s3://crabby-images/e8a38/e8a38eb82c5ade1931e6fa468b01140eb99e1cec" alt=""
Console output from this post: https://drive.google.com/file/d/1XGBCsNNTmT9hi8VAV9sA-sOwiWbUWvDT/view?usp=sharing
#3 Rebuild the FSBL
(A) Click debugfsblbsp [standalone on psu_cortexa53_0]
(B) Click Build
data:image/s3,"s3://crabby-images/d0112/d01127409aa0828fbf56c8f52a91e8f63b4c4c2d" alt=""
You should see:
data:image/s3,"s3://crabby-images/7af89/7af890863d22de8c6cd53d3e0aa2c6ff8c09f309" alt=""
Console output from this post: https://drive.google.com/file/d/1XI7fGFNiOQ6WR4WNfO1Ys-uLe94lYIX1/view?usp=sharing
#4 Test.
(A) Open xfsbl_ddr_init.c
(B) Go to 6627:
ConfigIic = XIicPs_LookupConfig(XPAR_PSU_I2C_1_DEVICE_ID);
(C) Double-click to set a breakpoint
(D) Click debug
(E) When it hits:
while (FsblStage<=XFSBL_STAGE_DEFAULT) {
…click Resume
data:image/s3,"s3://crabby-images/23a48/23a4870a427f69b35efe02a2477287578fdf2f92" alt=""
(F) When it hits:
Status = XFsbl_IicReadSpdEeprom(SpdData);
…click Step Into
data:image/s3,"s3://crabby-images/386a1/386a1fff7f24dcb5a026acb3ad5e57302680ed73" alt=""
You should see the source code inside the BSP:
data:image/s3,"s3://crabby-images/07fc5/07fc53d4ce8197878978d3a6973b980525e389c2" alt=""
References
Vitis 2019.2 - Embedded Software Development - Design Hub https://www.xilinx.com/support/documentation-navigation/design-hubs/2019-2/dh0089-vitis-embedded.html
Zynq UltraScale+ FSBL Wiki https://xilinx-wiki.atlassian.net/wiki/spaces/A/pages/18842019/Zynq+UltraScale+FSBL
Vitis Unified Software Platform Documentation Embedded Software Development UG1400 (v2019.2) March 18, 2020 https://www.xilinx.com/support/documentation/sw_manuals/xilinx2019_2/ug1400-vitis-embedded.pdf
Vitis Unified Software Platform Documentation Application Acceleration Development UG1393 (v2019.2) February 28, 2020 https://www.xilinx.com/support/documentation/sw_manuals/xilinx2019_2/ug1393-vitis-application-acceleration.pdf
Xilinx logo clipped from xilinx.com