Debug with Arm DS¶
Install Arm DS¶
Please refer to the official Arm Development Studio Page 1 for details. Here
Version: 2020.b Build: 2020110909
is used in the following example.
data:image/s3,"s3://crabby-images/359d0/359d0058518b1f6206cff0eb091b7e9e648999cf" alt="Arm DS Version"
Download Arm FVP BaseR AEMv8-R¶
Please refer to official FVP page 2 for download instructions. Here $FVP_D
is used to indicate which directory is FVP located.
Use DS perspective¶
From menu choose Window -> Perspective -> Open Perspective -> Other...
:
data:image/s3,"s3://crabby-images/30c24/30c24b99b9bae370dd8ffc69973bf0543b6d8148" alt="Arm DS Perspective choose Other..."
In the opened window, choose Development Studio (default)
:
data:image/s3,"s3://crabby-images/f77af/f77afd9bf8f3fe6676a184646d751429d7f9cb70" alt="Arm DS Perspective choose DS"
Create a new configuration database¶
Create a new configuration database by selecting File -> New -> Other... -> Configuration Database
:
data:image/s3,"s3://crabby-images/82457/8245773a41f5ff42d106926a029f2c7ca9186294" alt="Arm DS create new configuration database"
Choose a name for the database. Here Zephyr
is used:
data:image/s3,"s3://crabby-images/4585a/4585a5867e5e06d6533dc4676e566af9e7b64fac" alt="Arm DS create new configuration database: choose database name"
Click Finish
and the new configuration database can be seen in Project Explorer
:
data:image/s3,"s3://crabby-images/2ffd9/2ffd9d4213872c6628389f9074f98944298f7efa" alt="Arm DS create new configuration database: shown in project explorer"
Create a new model configuration¶
Right click Zephyr
in Project Explorer
, choose New -> Model Configuration
:
data:image/s3,"s3://crabby-images/543ec/543ec6d4401252507675db8533d8a1137044024b" alt="Arm DS create new model configuration"
In the opened window:
Choose
Iris
forModel Interface
, thenNext >
.Choose
Launch and connect to specific model
, thenNext >
.Set
Model Path
to$FVP_D/FVP_BaseR_AEMv8R
, thenFinish
.
data:image/s3,"s3://crabby-images/379a3/379a39e0a0de98a294c8c7848bf6736702eeac90" alt="Arm DS create new model configuration: set model path"
Then in FVP_BaseR_AEMv8R
tab, change ARMAEMv8-R_
to V8R64-Generic
,
click Save
and then click Import
:
data:image/s3,"s3://crabby-images/39c9d/39c9d3feca4e589a41c227478e1f6d6dcfd5a7da" alt="Arm DS create new model configuration: import"
Create a new launch configuration¶
From Project Explorer
, right click FVP_BaseR_AEMv8R
and select Debug as -> Debug configurations...
:
data:image/s3,"s3://crabby-images/c35c2/c35c22bc884f142ab8e8a335ac9cfb24f7d87c3b" alt="Arm DS create new launch configuration: context menu"
Select Generic Arm C/C++ Application
and click New launch configuration
button.
A new configuration named New_configuration
will be created.
In
Connection
tab:In
Select target
box, selectImported -> FVP_BaseR_AEMv8R -> Bare Metal Debug -> ARMAEMv8-R_MP_0
In
Connections
box, setModel parameters
to:-C bp.dram.enable_atomic_ops=1 -C bp.sram.enable_atomic_ops=1 -C bp.refcounter.non_arch_start_at_default=1 -C gic_distributor.GICD_CTLR-DS-1-means-secure-only=1 -C gic_distributor.has-two-security-states=0 -C bp.vis.disable_visualisation=1 -C cluster0.has_aarch64=1 -a /home/fengqi/zephyrproject/build/zephyr/zephyr.elf
These parameters are passed to
FVP_BaseR_AEMv8R
when launches. RunFVP_BaseR_AEMv8R --help
to see all command line options. RunFVP_BaseR_AEMv8R --list-params
to see all supported parameters. The filezephyr.elf
specified by-a
is the binary built from Zephyr.
data:image/s3,"s3://crabby-images/34cd7/34cd7d18f144bc5783c92dd85c192a3e1241a856" alt="Arm DS create new launch configuration: connection"
In
Files
tab:In
Files
box, setLoad symbols from file
to full path ofzephyr.elf
that you built.
data:image/s3,"s3://crabby-images/65ff4/65ff4632b6b26451f9c40452be1c38d65b2b267c" alt="Arm DS create new launch configuration: files"
In
Debugger
tab:In
Run control
box, checkExecute debugger commands
and insert:add-symbol-file "/home/fengqi/zephyrproject/build/zephyr/zephyr.elf" EL1S:0
Replace
/home/fengqi/zephyrproject/build/zephyr/zephyr.elf
with your local path.In
Paths
box, setSource search directory
to the path to Zephyr source code.
data:image/s3,"s3://crabby-images/54c94/54c94b78a522107d8b74fb01dd6d67e1091718ff" alt="Arm DS create new launch configuration: debugger"
After all these changes are made, click Apply
, then click Debug
. DS will
launch FVP_BaseR_AEMv8R
and connect to it. You can see a new session is
connected in Debug Control
window.
data:image/s3,"s3://crabby-images/29a26/29a26cc2ad7ea672f75a34d57febb9e8fd0a720a" alt="Arm DS working"