-
Notifications
You must be signed in to change notification settings - Fork 35
Debugging with GDB
Eduardo Bart edited this page Oct 3, 2024
·
3 revisions
This is a documentation on how to use GDB to debug privileged code with the Cartesi machine emulator.
- Add
source <EMULATOR_PATH>/tools/gdb/gdbinit
to your$HOME/.gdbinit
file to add custom cartesi-machine to your GDB, remember to replace<EMULATOR_PATH>
with your emulator path. - Run
cartesi-machine --gdb
in a terminal, the machine will start stopped at cycle 0, waiting for a connection from GDB. - Run
riscv64-cartesi-linux-gnu-gdb -ex "set arch riscv:rv64" -ex "target remote 127.0.0.1:1234"
in another terminal. You can use any GDB, like the one provided in your Linux distribution, as long it is compiled with RISC-V support. - Step machine cycles with
stepc
commands or use other GDB commands.
- You need to compile your kernel or test that you would like to debug with
debug information into a binary ELF file (using
.bin
will not work). - Connect GDB with
riscv64-cartesi-linux-gnu-gdb -ex "set arch riscv:rv64" -ex "target remote 127.0.0.1:1234" <elf>
where<elf>
is your kernel or test ELF file compiled with debug information. - To view C/C++ code, make sure you run GDB client in a directory that is able to access the source files relative to the ELF binary being debugged.
The following is a list of all custom GDB commands contained in tools/gdb/gdbinit
:
-
cycles
retrieve machine cycles -
stepc [n]
step 1 orn
mcycles -
stepu <n>
step until mcycle -
reg <name>
get register value, .e.g.reg mcycle
-
reg <name>=1
set register value, .e.g.reg mcycle=0
-
hash
print machine hash in the current state -
store <dir>
store machine state intodir
-
lua "<code>"
execute an arbitrary machine Lua code, e.g.lua "print(machine:read_mcycle())"
-
breakpc <address>
toggle a hardware breakpoint at PC
Aliases:
-
sc
alias forstepc
-
su
alias forstepu
-
bpc
alias forbreakpc
- You can step cycle by cycle quickly by using the command
sc
and pressing enter multiple times. - You can step multiple cycles quickly by using the command
sc <n>
and pressing enter multiple times. - Use
layout asm
to open a window to see the current instructions being executed. - Use
layout regs
to open a window to see all registers values and highlight register changes. - Use
break *0x2000
to break at a specific PC (0x2000
in this case) and thencontinue
to let the machine run until reaching that PC. - Use
breakpc 0x2000
to break at a specific PC even when the memory range is not available yet, and thencontinue
to let the machine run until reaching that PC. - If you need to place breakpoints after kernel boot, placing it at the session start and letting it continue can be very slow. Prefer to use
stepu <n>
where<n>
is a number of cycles large enough to let the kernel boot first, and just later after boot place your breakpoint and let it continue.
You could add the following lines to $HOME/.gdbinit
to improve your debugging session experience.
# make gdb more quiet
set verbose off
set confirm off
# save command history
set history filename ~/.gdb_history
set history save
# cartesi machine debugging commands
source <EMULATOR_PATH>/tools/gdb/gdbinit
Remember to replace <EMULATOR_PATH>
with your emulator path.