This article explains how to create, build and debug a Linux® user space application for STM32 MPU.
1. Create a user space executable project[edit source]
In the Cortex®-A7 sub-project context, named here MP157C-DK2_CA7, right-click and select Create a userspace Project...
data:image/s3,"s3://crabby-images/a2e6c/a2e6c082bc6c665819273f6d0a66d99a7d2b6777" alt="User space project wizard shortcut User space project wizard shortcut"
In the example, an executable project type in C language is selected.
Note that the user space project uses by default the SDK version associated to Cortex®-A7 sub-project.
data:image/s3,"s3://crabby-images/18ab0/18ab0cbe366671d03ebee12501c6298316fc2f9a" alt="User space project creation wizard User space project creation wizard"
2. Build[edit source]
- Select your project, right-click and then Build Project.
data:image/s3,"s3://crabby-images/bf97b/bf97b8ab0486fb2def714daad08b27af4e0af49d" alt="Executable Build Executable Build"
3. Prepare Debug Configuration[edit source]
You can check boot messages via Linux® console opened with butterfly icon (shown below), but remember this console cannot be shared outside STM32CubeIDE (minicom,...).
data:image/s3,"s3://crabby-images/6cae2/6cae2e39e0840d8cb000a8622173991ce707a071" alt="CubeIDELinuxConsole.png"
In order to debug user space application, your target must be Linux® booted and network connected.
To check network connection, start the Target Status widget in the bottom right corner of the window.
data:image/s3,"s3://crabby-images/aed2f/aed2f6d5e946f859514ad7f6f7f5b933208028fb" alt="Target Status - green Target Status - green"
Check also How to set up proxy and P2P Ethernet connection with STM32CubeIDE if you have some proxy problem.
4. Set Debug Configuration[edit source]
- Select your project, right-click Debug as... > Debug Configurations,
- select STM32 Cortex-A Remote Application.
data:image/s3,"s3://crabby-images/769ea/769ea138a2b17e4dd9707135245ec0391d82b030" alt="Debug configuration shortcut Debug configuration shortcut"
The default connection proposed is "MPU SSH", corresponding to the target IP address discovered by Target Status. The default destination directory is /home/root.
data:image/s3,"s3://crabby-images/838aa/838aaf96c37de352a6ba1af742265fd355e54b5e" alt="User space debug configuration - main tab User space debug configuration - main tab"
5. Debug[edit source]
Click Debug :
- Executable is downloaded to the target,
- GDBServer is launched on the target,
- GDBClient is launched on the workstation and can exchange via the network with GDBServer.
data:image/s3,"s3://crabby-images/db23f/db23f35923a788ed80fc7cb0b2afe1119a220b84" alt="User space debug User space debug"