This document covers various topics to help you as you develop and debug the zxdb debugger:
- Run tests
- Reload debug_agent.cmafter a new build
- Enable debug logging in debug_agent
- Enable debug logging in zxdb
- Launch zxdb in another debugger
- Debug debug_agentin anotherdebug_agent
Run tests
To run the zxdb frontend tests:
fx test zxdb_testsTo run the debug_agent tests:
fx test debug_agent_unit_tests
fx test debug_agent_integration_testsTo run the end-to-end tests:
fx test --e2e zxdb_e2e_testsReload debug_agent.cm after a new build
Since the debug_agent_launcher is a long-running process, your system does
not try to update the debug_agent package after the first ffx debug connect
invocation.
To force the system to unload debug_agent.cm:
ffx component stop /core/debug_agentEnable debug logging in debug_agent
To enable the debug logging of the debug_agent, add
--set-severity core/debug_agent#DEBUG to fx log. For example:
fx log --set-severity core/debug_agent#DEBUG --tag debug_agent --hide_metadata --prettyEnable debug logging in zxdb
To enable debug logging in zxdb:
ffx debug connect -- --debug-modeLaunch zxdb in another debugger
You can have ffx debug launch zxdb in another debugger such as lldb. For
example:
ffx debug connect --debugger lldbThis command brings the lldb shell and you can use run to start zxdb.
Alternatively, instead of lldb you could specify another debugger such as gdb.
However, if you use gdb, you may run into some of the following issues:
- Older versions of gdbmay not support all DWARF 5 standards. Which may result some missing information such as source file listing.
- Ctrl-Cdoes not return you from zxdb to- gdb. To stop zxdb, from another terminal, run:- pkill -INT zxdb`
Debug debug_agent in another debug_agent
You can attach a debug_agent to another debug_agent:
- Run the debugger that attaches to the "to-be-debugged" - debug_agentthat you want to debug:- ffx debug connect
- From the zxdb console, run: - attach debug_agent Waiting for process matching "debug_agent". Type "filter" to see the current filters. Attached Process 1 state=Running koid=345223 name=debug_agent.cm Attached Process 2 state=Running koid=345403 name=/pkg/bin/debug_agent
- The first - debug_agentcaptures the launcher and itself. You can detach the processes to avoid any deadlock.- For example, to detach process 1: - [zxdb] pr 1 detach- For example, to detach process 2: - [zxdb] pr 2 detach
- Create a breakpoint on the - $mainfunction:- [zxdb] break $main
- From another terminal, launch another zxdb instance: - ffx debug connect
- In the initial terminal with zxdb, you should see an output like: - Attached Process 1 state=Running koid=12345 name=/pkg/bin/debug_agent Breakpoint 1 now matching 1 addrs for $main 🛑 process 1 on bp 1 main(int, const char**) • main.cc:101 99 100 int main(int argc, const char* argv[]) { ▶ 101 debug_agent::CommandLineOptions options; 102 cmdline::Status status = ParseCommandLine(argc, argv, &options); 103 if (status.has_error()) {- You now have two instances of zxdb running.