GDB-8.0

Introduction to GDB

GDB, the GNU Project debugger, allows you to see what is going on “inside” another program while it executes -- or what another program was doing at the moment it crashed. Note that GDB is most effective when tracing programs and libraries that were built with debugging symbols and not stripped.

This package is known to build and work properly using an LFS-8.1 platform.

Package Information

GDB Dependencies

Optional

DejaGnu-1.6 (for tests), Doxygen-1.8.13, GCC-7.2.0 (gfortran, for some tests), Guile-2.2.2 (currently broken), Python-2.7.13, rustc-1.19.0 (for some tests), Valgrind-3.13.0, and SystemTap (run-time dependency, also used in a few tests)

User Notes: http://wiki.linuxfromscratch.org/blfs/wiki/gdb

Installation of GDB

Install GDB by running the following commands:

./configure --prefix=/usr --with-system-readline --without-guile &&
make

Optionally, to build the API documentation using Doxygen-1.8.13, run:

make -C gdb/doc doxy

To test the results, issue:

pushd gdb/testsuite &&
make  site.exp      &&
echo  "set gdb_test_timeout 120" >> site.exp &&
runtest TRANSCRIPT=y
popd

See gdb/testsuite/README and TestingGDB. There are many problems with the test suite:

  • Clean directories are needed if re-running the tests. For that reason, it is recommended to make a copy of the compiled source code directory before the tests in case you need to run the tests again.

  • Results depend on installed compilers.

  • There are a large number of timeouts (there is a variable that can be set to increase time for timeout, but changing it will result in a different number of tests being run).

  • There are failures associated with system readline 6.x.

  • A few tests assume that the header file <sys/sdt.h>, part of SystemTap, is present.

  • About 3% of the tests fail (out of over 35000 tests).

Now, as the root user:

make -C gdb install

If you have built the API documentation, it is now in gdb/doc/doxy. You can install it (as the root user):

install -d /usr/share/doc/gdb-8.0 &&
rm -rf gdb/doc/doxy/xml &&
cp -Rv gdb/doc/doxy /usr/share/doc/gdb-8.0

Command Explanations

--without-guile: This switch disables support for Guile since version 2.2 changed the way that C ports were handled.

--with-system-readline: This switch forces GDB to use the copy of Readline installed in LFS.

Contents

Installed Programs: gcore, gdb and gdbserver
Installed Library: libinproctrace.so
Installed Directories: /usr/{include,share}/gdb and /usr/share/doc/gdb-8.0

Short Descriptions

gcore

generates a core dump of a running program.

gdb

is the GNU Debugger.

gdbserver

is a remote server for the GNU debugger (it allows programs to be debugged from a different machine).

libinproctrace.so

contains functions for the in-process tracing agent. The agent allows for installing fast tracepoints, listing static tracepoint markers, probing static tracepoints markers, and starting trace monitoring.

Last updated on 2017-08-23 10:58:13 -0700