You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.9 KiB
53 lines
1.9 KiB
// -*- mode:doc; -*-
|
|
// vim: set syntax=asciidoc:
|
|
|
|
==== Using +gdb+ in Buildroot
|
|
|
|
Buildroot allows to do cross-debugging, where the debugger runs on the
|
|
build machine and communicates with +gdbserver+ on the target to
|
|
control the execution of the program.
|
|
|
|
To achieve this:
|
|
|
|
* If you are using an _internal toolchain_ (built by Buildroot), you
|
|
must enable +BR2_PACKAGE_HOST_GDB+, +BR2_PACKAGE_GDB+ and
|
|
+BR2_PACKAGE_GDB_SERVER+. This ensures that both the cross gdb and
|
|
gdbserver get built, and that gdbserver gets installed to your target.
|
|
|
|
* If you are using an _external toolchain_, you should enable
|
|
+BR2_TOOLCHAIN_EXTERNAL_GDB_SERVER_COPY+, which will copy the
|
|
gdbserver included with the external toolchain to the target. If your
|
|
external toolchain does not have a cross gdb or gdbserver, it is also
|
|
possible to let Buildroot build them, by enabling the same options as
|
|
for the _internal toolchain backend_.
|
|
|
|
Now, to start debugging a program called +foo+, you should run on the
|
|
target:
|
|
|
|
----------------------------
|
|
gdbserver :2345 foo
|
|
----------------------------
|
|
|
|
This will cause +gdbserver+ to listen on TCP port 2345 for a connection
|
|
from the cross gdb.
|
|
|
|
Then, on the host, you should start the cross gdb using the following
|
|
command line:
|
|
|
|
----------------------------
|
|
<buildroot>/output/host/bin/<tuple>-gdb -ix <buildroot>/output/staging/usr/share/buildroot/gdbinit foo
|
|
----------------------------
|
|
|
|
Of course, +foo+ must be available in the current directory, built
|
|
with debugging symbols. Typically you start this command from the
|
|
directory where +foo+ is built (and not from +output/target/+ as the
|
|
binaries in that directory are stripped).
|
|
|
|
The +<buildroot>/output/staging/usr/share/buildroot/gdbinit+ file will tell the
|
|
cross gdb where to find the libraries of the target.
|
|
|
|
Finally, to connect to the target from the cross gdb:
|
|
|
|
----------------------------
|
|
(gdb) target remote <target ip address>:2345
|
|
----------------------------
|
|
|