| # Debugger (zxdb) |
| |
| Zxdb is a console debugger for native code compiled with DWARF symbols (C, C++ |
| and Rust). The frontend runs on the host computer and connects to the on-device |
| `debug_agent`. This document describes how to set up these processes. |
| |
| ## Running the agent |
| |
| The `debug_agent` is run on the target device along with the port number that |
| it should listen to for incoming client connections. Typically this command |
| will be run from a console after [ssh-ing](ssh.md) in to the system: |
| |
| ``` |
| run fuchsia-pkg://fuchsia.com/debug_agent#meta/debug_agent.cmx --port=2345 |
| ``` |
| |
| ## Connecting the client |
| |
| The `zxdb` client program is run on the host computer. It can be connected to |
| the `debug_agent` via the interactive `connect` debugger command or it can |
| automatically connect based on a command-line flag. Both IPv4 and IPv6 |
| addresses are supported (see [device discovery](device_discovery.md) to find |
| the address). The port should match the port number passed to the agent. |
| |
| ``` |
| zxdb -c "[f370::5051:ff:1e53:589a%qemu]:2345" |
| ``` |
| |
| ### Connecting via a script |
| |
| Scripts may want to automatically launch the agent and client automatically. |
| The script should wait for the port to be open on the target system before |
| launching the client. Automatic retry is not yet implemented in the client. |
| |
| To clean up the debug agent gracefully when the client exits, pass the |
| `--quit-agent-on-exit` command-line flag to the client. |
| |
| ## Specifying symbol paths |
| |
| The debugger expects unstripped ELF files to be available on the local host |
| system. Symbols on the target are not used. The location where the local build |
| stores symbols must be passed to the `zxdb` client. |
| |
| For more information on how to specify symbol paths, see [set the symbol |
| location](/docs/development/debugger/README.md#set-symbol-location) |