The scope of this document is to demonstrate multiprocessor debugging using MMUART Example SoftConsole project on the PolarFire SoC ICICLE kit. This also includes creating a debug configuration, adding breakpoints, and halting the execution flow to perform step-by-step debug of the application.
PolarFire SoC FPGA supports 5x 64-bit RISC-V cores — one E51 monitor core and four U54 application cores. The Bare Metal MMUART Example SoftConsole project contains application code specific to each processor core. The default build configuration of the application is set to debug the application from loosely integrated memory (LIM) by default. The E51 processor invokes the U54_1 processor from wait for interrupt (WFI) mode. The U54_1 processor runs the application code and displays the serial terminal messages. Remaining processor cores (U54_2, U54_3, and U54_4) remain in WFI mode. The MMUART Example SoftConsole project is preconfigured to demonstrate multiprocessor debugging. All the processor cores cannot be debugged concurrently. Halting the application execution flow halts all the processor cores.
- ICICLE Kit (MPFS250T_ES-FCVG484E)
- SoftConsole v2021.1
- Libero SoC v2021.1
- Host PC - Windows 10 OS
Before debugging the user application, ensure to complete the following steps:
- Setting up the jumpers on the ICICLE Kit.
- Use FlashPro Express to program the ICICLE Kit with the PolarFire SoC ICICLE Kit Reference Design job file.
To debug the application, perform the following step:
-
Clone or download the polarfire-soc-bare-metal-examples project as shown in the following figure and extract the same on the host PC.
-
Launch SoftConsole IDE. In the Workspace Launcher dialog box, paste the path where the example project is stored as the workspace location and click OK. The SoftConsole main window opens.
-
In the Project Explorer window, click Import projects... as shown in the following figure. Expand the General drop-down list and select Existing Projects into Workspace, then click Next.
-
Click Browse..., and navigate to the location where the mpfs-mmuart > mpfs-mmuart-interrupt project folder is located, select the folder and then, click Finish.
-
By default, the e51 releases U54_1 from wait for interrupt (WFI) mode. Other processor cores can also be released from WFI mode.
-
In the Project Explorer view, right-click the mpfs-mmuart-interrupt project and select Build Project as shown in the following figure. Ensure that no errors are displayed in the build result.
-
Select the mpfs-mmuart-interrupt project as shown in following figure. Click Run > Debug Configurations... from the SoftConsole toolbar as shown in the following figure. Debug Configurations window appears.
-
In the Main tab, ensure that the C/C++ Application: field contains the correct executable name as shown in the following figure.
-
In the Debugger tab, ensure that the Config options field contains the correct command line options as shown in the following figure.
-
In the Startup tab, enable Set breakpoint at: and Continue check box as shown in the following figure. Set the breakpoint at u54_1.
-
Click Debug.
-
The Confirm Perspective Switch dialog box opens and click Switch. The debugger halts the execution at the u54_1 function.
-
Right-click wherever breakpoint is required in the application code and select Add Breakpoint... as shown in the following figure. The breakpoints can be added in each hart application code. The breakpoints are used to pause the execution flow. The debugger switches between the hart source code files to halt the execution depending on the breakpoints set.
-
In the following figure, the Breakpoints tab lists the breakpoints added in the application project. When the debugger halts at any breakpoint, the user can perform step debug (Step Into or Step Over), or resume the debugger. In the Debug window on the left pane, call stack of all the harts is displayed. Each Thread represents one hart. For Example, Thread #1 represents E51 monitor core, Thread #4 represents U54_3 processor core.
-
When the program execution is halted at the breakpoint, the values of the local variables can be seen using Variables tab as shown in the following figure. Selecting another function in the call stack window displays all the local variables in that function in the Variables tab.
-
The memory content can be monitored for any variables declared in the application using Memory tab as shown in the following figure.
-
To terminate the debugging of the debugging session, click Terminate on the SoftConsole toolbar and close SoftConsole.
This concludes the debugging process of the demo.