1999-04-16 03:35:26 +02:00
|
|
|
README for GDBserver & GDBreplay
|
|
|
|
by Stu Grossman and Fred Fish
|
|
|
|
|
|
|
|
Introduction:
|
|
|
|
|
|
|
|
This is GDBserver, a remote server for Un*x-like systems. It can be used to
|
|
|
|
control the execution of a program on a target system from a GDB on a different
|
|
|
|
host. GDB and GDBserver communicate using the standard remote serial protocol
|
|
|
|
implemented in remote.c, and various *-stub.c files. They communicate via
|
|
|
|
either a serial line or a TCP connection.
|
|
|
|
|
* linux-low.c (linux_attach_lwp): Do not _exit after errors.
(linux_kill, linux_detach): Clean up the process list.
* remote-utils.c (remote_open): Improve port number parsing.
(putpkt_binary, input_interrupt): Only send interrupts if the target
is running.
* server.c (extended_protocol): Make static.
(attached): Define earlier.
(exit_requested, response_needed, program_argv): New variables.
(target_running): New.
(start_inferior): Clear attached here.
(attach_inferior): Set attached here.
(require_running): Define.
(handle_query): Use require_running and target_running. Implement
"monitor exit".
(handle_v_attach, handle_v_run): New.
(handle_v_requests): Use require_running. Handle vAttach and vRun.
(gdbserver_usage): Update.
(main): Redo argument parsing. Handle --debug and --multi. Handle
--attach along with other options or after the port. Save
program_argv. Support no initial program. Resynchronize
communication with GDB after an error. Handle "monitor exit".
Use require_running and target_running. Always allow the extended
protocol. Do not error out for Hc0 or Hc-1. Do not automatically
restart in extended mode.
* README: Refer to the GDB manual. Update --attach usage.
* remote.c (struct remote_state): Add cached_wait_status.
(remote_exec_file): New variable.
(PACKET_vAttach, PACKET_vRun): New constants.
(extended_remote_restart): Do not query for status.
(struct start_remote_args): New.
(remote_start_remote): Take it as a second argument. Check
whether the target is running. Issue an error for non-running
non-extended targets. Cache the wait status. Set inferior_ptid
here.
(remote_open_1): Prompt to disconnect non-running targets. Make
sure the target is marked running. Do not set inferior_ptid here.
Update call to remote_start_remote. Do not call remote_check_symbols
if the target is not running.
(remote_detach_1): Rename from remote_detach. Take an EXTENDED
argument. Handle a non-running target.
(remote_detach): Use it.
(extended_remote_detach): New.
(remote_disconnect): Fix typo. Use remoute_mourn_1.
(extended_remote_attach_1, extended_remote_attach)
(extended_async_remote_attach): New.
(remote_vcont_resume): Remove unused variable.
(remote_wait, remote_async_wait): Use any cached wait status.
(putpkt_binary, getpkt): Clear any cached wait status.
(extended_remoute_mourn_1): New.
(extended_remote_mourn): Use it.
(extended_async_remote_mourn, extended_remote_run): New.
(extended_remote_create_inferior_1): New.
(extended_remote_create_inferior): Use it.
(extended_remote_async_create_inferior): Likewise.
(remote_xfer_partial): Skip for non-executing targets.
(init_extended_remote_ops): Set to_detach and to_attach.
(init_extended_async_remote_ops): Likewise. Use
extended_async_remote_mourn.
(_initialize_remote): Register vAttach, vRun, and
set remote exec-file.
* NEWS: Mention vAttach, vRun, and gdbserver extended-remote support.
* gdb.server/ext-attach.c, gdb.server/ext-attach.exp,
gdb.server/ext-run.exp: New files.
* lib/gdbserver-support.exp (gdbserver_download): New.
(gdbserver_start): New. Update gdbserver expected
output.
(gdbserver_spawn): Use them.
(gdbserver_start_extended): New.
* gdb.texinfo (Using the `gdbserver' Program): Add security
warning. Rearrange into subsections and subsubsections. Document
--multi and --debug. Correct --with-sysroot typo. Update --attach
usage. Make load reference clearer. Document monitor exit.
(Remote Configuration): Document set remote exec-file, attach-packet,
and run-packet.
(Packets): Document vAttach and vRun.
2008-01-30 01:51:50 +01:00
|
|
|
For more information about GDBserver, see the GDB manual.
|
|
|
|
|
1999-04-16 03:35:26 +02:00
|
|
|
Usage (server (target) side):
|
|
|
|
|
|
|
|
First, you need to have a copy of the program you want to debug put onto
|
|
|
|
the target system. The program can be stripped to save space if needed, as
|
|
|
|
GDBserver doesn't care about symbols. All symbol handling is taken care of by
|
|
|
|
the GDB running on the host system.
|
|
|
|
|
|
|
|
To use the server, you log on to the target system, and run the `gdbserver'
|
|
|
|
program. You must tell it (a) how to communicate with GDB, (b) the name of
|
|
|
|
your program, and (c) its arguments. The general syntax is:
|
|
|
|
|
|
|
|
target> gdbserver COMM PROGRAM [ARGS ...]
|
|
|
|
|
|
|
|
For example, using a serial port, you might say:
|
|
|
|
|
|
|
|
target> gdbserver /dev/com1 emacs foo.txt
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
This tells GDBserver to debug emacs with an argument of foo.txt, and to
|
|
|
|
communicate with GDB via /dev/com1. GDBserver now waits patiently for the
|
1999-04-16 03:35:26 +02:00
|
|
|
host GDB to communicate with it.
|
|
|
|
|
|
|
|
To use a TCP connection, you could say:
|
|
|
|
|
|
|
|
target> gdbserver host:2345 emacs foo.txt
|
|
|
|
|
|
|
|
This says pretty much the same thing as the last example, except that we are
|
|
|
|
going to communicate with the host GDB via TCP. The `host:2345' argument means
|
|
|
|
that we are expecting to see a TCP connection from `host' to local TCP port
|
|
|
|
2345. (Currently, the `host' part is ignored.) You can choose any number you
|
|
|
|
want for the port number as long as it does not conflict with any existing TCP
|
|
|
|
ports on the target system. This same port number must be used in the host
|
|
|
|
GDBs `target remote' command, which will be described shortly. Note that if
|
2010-05-02 18:10:03 +02:00
|
|
|
you chose a port number that conflicts with another service, GDBserver will
|
1999-04-16 03:35:26 +02:00
|
|
|
print an error message and exit.
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
On some targets, GDBserver can also attach to running programs. This is
|
2002-02-20 00:48:14 +01:00
|
|
|
accomplished via the --attach argument. The syntax is:
|
|
|
|
|
* linux-low.c (linux_attach_lwp): Do not _exit after errors.
(linux_kill, linux_detach): Clean up the process list.
* remote-utils.c (remote_open): Improve port number parsing.
(putpkt_binary, input_interrupt): Only send interrupts if the target
is running.
* server.c (extended_protocol): Make static.
(attached): Define earlier.
(exit_requested, response_needed, program_argv): New variables.
(target_running): New.
(start_inferior): Clear attached here.
(attach_inferior): Set attached here.
(require_running): Define.
(handle_query): Use require_running and target_running. Implement
"monitor exit".
(handle_v_attach, handle_v_run): New.
(handle_v_requests): Use require_running. Handle vAttach and vRun.
(gdbserver_usage): Update.
(main): Redo argument parsing. Handle --debug and --multi. Handle
--attach along with other options or after the port. Save
program_argv. Support no initial program. Resynchronize
communication with GDB after an error. Handle "monitor exit".
Use require_running and target_running. Always allow the extended
protocol. Do not error out for Hc0 or Hc-1. Do not automatically
restart in extended mode.
* README: Refer to the GDB manual. Update --attach usage.
* remote.c (struct remote_state): Add cached_wait_status.
(remote_exec_file): New variable.
(PACKET_vAttach, PACKET_vRun): New constants.
(extended_remote_restart): Do not query for status.
(struct start_remote_args): New.
(remote_start_remote): Take it as a second argument. Check
whether the target is running. Issue an error for non-running
non-extended targets. Cache the wait status. Set inferior_ptid
here.
(remote_open_1): Prompt to disconnect non-running targets. Make
sure the target is marked running. Do not set inferior_ptid here.
Update call to remote_start_remote. Do not call remote_check_symbols
if the target is not running.
(remote_detach_1): Rename from remote_detach. Take an EXTENDED
argument. Handle a non-running target.
(remote_detach): Use it.
(extended_remote_detach): New.
(remote_disconnect): Fix typo. Use remoute_mourn_1.
(extended_remote_attach_1, extended_remote_attach)
(extended_async_remote_attach): New.
(remote_vcont_resume): Remove unused variable.
(remote_wait, remote_async_wait): Use any cached wait status.
(putpkt_binary, getpkt): Clear any cached wait status.
(extended_remoute_mourn_1): New.
(extended_remote_mourn): Use it.
(extended_async_remote_mourn, extended_remote_run): New.
(extended_remote_create_inferior_1): New.
(extended_remote_create_inferior): Use it.
(extended_remote_async_create_inferior): Likewise.
(remote_xfer_partial): Skip for non-executing targets.
(init_extended_remote_ops): Set to_detach and to_attach.
(init_extended_async_remote_ops): Likewise. Use
extended_async_remote_mourn.
(_initialize_remote): Register vAttach, vRun, and
set remote exec-file.
* NEWS: Mention vAttach, vRun, and gdbserver extended-remote support.
* gdb.server/ext-attach.c, gdb.server/ext-attach.exp,
gdb.server/ext-run.exp: New files.
* lib/gdbserver-support.exp (gdbserver_download): New.
(gdbserver_start): New. Update gdbserver expected
output.
(gdbserver_spawn): Use them.
(gdbserver_start_extended): New.
* gdb.texinfo (Using the `gdbserver' Program): Add security
warning. Rearrange into subsections and subsubsections. Document
--multi and --debug. Correct --with-sysroot typo. Update --attach
usage. Make load reference clearer. Document monitor exit.
(Remote Configuration): Document set remote exec-file, attach-packet,
and run-packet.
(Packets): Document vAttach and vRun.
2008-01-30 01:51:50 +01:00
|
|
|
target> gdbserver --attach COMM PID
|
2002-02-20 00:48:14 +01:00
|
|
|
|
|
|
|
PID is the process ID of a currently running process. It isn't necessary
|
2010-05-02 18:10:03 +02:00
|
|
|
to point GDBserver at a binary for the running process.
|
2002-02-20 00:48:14 +01:00
|
|
|
|
1999-04-16 03:35:26 +02:00
|
|
|
Usage (host side):
|
|
|
|
|
|
|
|
You need an unstripped copy of the target program on your host system, since
|
|
|
|
GDB needs to examine it's symbol tables and such. Start up GDB as you normally
|
|
|
|
would, with the target program as the first argument. (You may need to use the
|
|
|
|
--baud option if the serial line is running at anything except 9600 baud.)
|
|
|
|
Ie: `gdb TARGET-PROG', or `gdb --baud BAUD TARGET-PROG'. After that, the only
|
|
|
|
new command you need to know about is `target remote'. It's argument is either
|
|
|
|
a device name (usually a serial device, like `/dev/ttyb'), or a HOST:PORT
|
|
|
|
descriptor. For example:
|
|
|
|
|
|
|
|
(gdb) target remote /dev/ttyb
|
|
|
|
|
|
|
|
communicates with the server via serial line /dev/ttyb, and:
|
|
|
|
|
|
|
|
(gdb) target remote the-target:2345
|
|
|
|
|
|
|
|
communicates via a TCP connection to port 2345 on host `the-target', where
|
2010-05-02 18:10:03 +02:00
|
|
|
you previously started up GDBserver with the same port number. Note that for
|
|
|
|
TCP connections, you must start up GDBserver prior to using the `target remote'
|
1999-04-16 03:35:26 +02:00
|
|
|
command, otherwise you may get an error that looks something like
|
|
|
|
`Connection refused'.
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
Building GDBserver:
|
2002-02-20 00:48:14 +01:00
|
|
|
|
2006-12-05 22:18:38 +01:00
|
|
|
The supported targets as of November 2006 are:
|
|
|
|
arm-*-linux*
|
2010-12-29 17:15:42 +01:00
|
|
|
bfin-*-uclinux
|
|
|
|
bfin-*-linux-uclibc
|
2006-12-05 22:18:38 +01:00
|
|
|
crisv32-*-linux*
|
|
|
|
cris-*-linux*
|
|
|
|
i[34567]86-*-cygwin*
|
|
|
|
i[34567]86-*-linux*
|
|
|
|
i[34567]86-*-mingw*
|
|
|
|
ia64-*-linux*
|
|
|
|
m32r*-*-linux*
|
|
|
|
m68*-*-linux*
|
|
|
|
m68*-*-uclinux*
|
|
|
|
mips*64*-*-linux*
|
|
|
|
mips*-*-linux*
|
|
|
|
powerpc[64]-*-linux*
|
|
|
|
s390[x]-*-linux*
|
|
|
|
sh-*-linux*
|
|
|
|
spu*-*-*
|
|
|
|
x86_64-*-linux*
|
1999-04-16 03:35:26 +02:00
|
|
|
|
Move gdbserver to top level
This patch moves gdbserver to the top level.
This patch is as close to a pure move as possible -- gdbserver still
builds its own variant of gnulib and gdbsupport. Changing this will
be done in a separate patch.
[v2] Note that, per Simon's review comment, this patch changes the
tree so that gdbserver is not built for or1k or score. This makes
sense, because there is apparently not actually a gdbserver port here.
[v3] This version of the patch also splits out some configury into a
new file, gdbserver/configure.host, so that the top-level configure
script can simply rely on it in order to decide whether gdbserver
should be built.
[v4] This version adds documentation and removes some unnecessary
top-level dependencies.
[v5] Update docs to mention "make all-gdbserver" and change how
top-level configure decides whether to build gdbserver, switching to a
single, shared script.
Tested by the buildbot.
ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
Pedro Alves <palves@redhat.com>
* src-release.sh (GDB_SUPPORT_DIRS): Add gdbserver.
* gdbserver: New directory, moved from gdb/gdbserver.
* configure.ac (host_tools): Add gdbserver.
Only build gdbserver on certain systems.
* Makefile.in, configure: Rebuild.
* Makefile.def (host_modules, dependencies): Add gdbserver.
* MAINTAINERS: Add gdbserver.
gdb/ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
* README: Update gdbserver documentation.
* gdbserver: Move to top level.
* configure.tgt (build_gdbserver): Remove.
* configure.ac: Remove --enable-gdbserver.
* configure: Rebuild.
* Makefile.in (distclean): Don't mention gdbserver.
Change-Id: I826b7565b54604711dc7a11edea0499cd51ff39e
2019-12-15 15:37:06 +01:00
|
|
|
Building GDBserver for your host is very straightforward. If you build
|
|
|
|
GDB natively on a host which GDBserver supports, it will be built
|
2010-05-02 18:10:03 +02:00
|
|
|
automatically when you build GDB. You can also build just GDBserver:
|
1999-04-16 03:35:26 +02:00
|
|
|
|
2002-02-20 00:48:14 +01:00
|
|
|
% mkdir obj
|
|
|
|
% cd obj
|
Move gdbserver to top level
This patch moves gdbserver to the top level.
This patch is as close to a pure move as possible -- gdbserver still
builds its own variant of gnulib and gdbsupport. Changing this will
be done in a separate patch.
[v2] Note that, per Simon's review comment, this patch changes the
tree so that gdbserver is not built for or1k or score. This makes
sense, because there is apparently not actually a gdbserver port here.
[v3] This version of the patch also splits out some configury into a
new file, gdbserver/configure.host, so that the top-level configure
script can simply rely on it in order to decide whether gdbserver
should be built.
[v4] This version adds documentation and removes some unnecessary
top-level dependencies.
[v5] Update docs to mention "make all-gdbserver" and change how
top-level configure decides whether to build gdbserver, switching to a
single, shared script.
Tested by the buildbot.
ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
Pedro Alves <palves@redhat.com>
* src-release.sh (GDB_SUPPORT_DIRS): Add gdbserver.
* gdbserver: New directory, moved from gdb/gdbserver.
* configure.ac (host_tools): Add gdbserver.
Only build gdbserver on certain systems.
* Makefile.in, configure: Rebuild.
* Makefile.def (host_modules, dependencies): Add gdbserver.
* MAINTAINERS: Add gdbserver.
gdb/ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
* README: Update gdbserver documentation.
* gdbserver: Move to top level.
* configure.tgt (build_gdbserver): Remove.
* configure.ac: Remove --enable-gdbserver.
* configure: Rebuild.
* Makefile.in (distclean): Don't mention gdbserver.
Change-Id: I826b7565b54604711dc7a11edea0499cd51ff39e
2019-12-15 15:37:06 +01:00
|
|
|
% path-to-toplevel-sources/configure --disable-gdb
|
|
|
|
% make all-gdbserver
|
|
|
|
|
|
|
|
(If you have a combined binutils+gdb tree, you may want to also
|
|
|
|
disable other directories when configuring, e.g., binutils, gas, gold,
|
|
|
|
gprof, and ld.)
|
1999-04-16 03:35:26 +02:00
|
|
|
|
2002-02-20 00:48:14 +01:00
|
|
|
If you prefer to cross-compile to your target, then you can also build
|
2010-05-02 18:10:03 +02:00
|
|
|
GDBserver that way. In a Bourne shell, for example:
|
1999-04-16 03:35:26 +02:00
|
|
|
|
2002-02-20 00:48:14 +01:00
|
|
|
% export CC=your-cross-compiler
|
Move gdbserver to top level
This patch moves gdbserver to the top level.
This patch is as close to a pure move as possible -- gdbserver still
builds its own variant of gnulib and gdbsupport. Changing this will
be done in a separate patch.
[v2] Note that, per Simon's review comment, this patch changes the
tree so that gdbserver is not built for or1k or score. This makes
sense, because there is apparently not actually a gdbserver port here.
[v3] This version of the patch also splits out some configury into a
new file, gdbserver/configure.host, so that the top-level configure
script can simply rely on it in order to decide whether gdbserver
should be built.
[v4] This version adds documentation and removes some unnecessary
top-level dependencies.
[v5] Update docs to mention "make all-gdbserver" and change how
top-level configure decides whether to build gdbserver, switching to a
single, shared script.
Tested by the buildbot.
ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
Pedro Alves <palves@redhat.com>
* src-release.sh (GDB_SUPPORT_DIRS): Add gdbserver.
* gdbserver: New directory, moved from gdb/gdbserver.
* configure.ac (host_tools): Add gdbserver.
Only build gdbserver on certain systems.
* Makefile.in, configure: Rebuild.
* Makefile.def (host_modules, dependencies): Add gdbserver.
* MAINTAINERS: Add gdbserver.
gdb/ChangeLog
2020-02-07 Tom Tromey <tom@tromey.com>
* README: Update gdbserver documentation.
* gdbserver: Move to top level.
* configure.tgt (build_gdbserver): Remove.
* configure.ac: Remove --enable-gdbserver.
* configure: Rebuild.
* Makefile.in (distclean): Don't mention gdbserver.
Change-Id: I826b7565b54604711dc7a11edea0499cd51ff39e
2019-12-15 15:37:06 +01:00
|
|
|
% path-to-topevel-sources/configure your-target-name --disable-gdb
|
2002-02-20 00:48:14 +01:00
|
|
|
% make
|
1999-04-16 03:35:26 +02:00
|
|
|
|
|
|
|
Using GDBreplay:
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
A special hacked down version of GDBserver can be used to replay remote
|
|
|
|
debug log files created by GDB. Before using the GDB "target" command to
|
1999-04-16 03:35:26 +02:00
|
|
|
initiate a remote debug session, use "set remotelogfile <filename>" to tell
|
2010-05-02 18:10:03 +02:00
|
|
|
GDB that you want to make a recording of the serial or tcp session. Note
|
|
|
|
that when replaying the session, GDB communicates with GDBreplay via tcp,
|
1999-04-16 03:35:26 +02:00
|
|
|
regardless of whether the original session was via a serial link or tcp.
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
Once you are done with the remote debug session, start GDBreplay and
|
|
|
|
tell it the name of the log file and the host and port number that GDB
|
|
|
|
should connect to (typically the same as the host running GDB):
|
1999-04-16 03:35:26 +02:00
|
|
|
|
|
|
|
$ gdbreplay logfile host:port
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
Then start GDB (preferably in a different screen or window) and use the
|
|
|
|
"target" command to connect to GDBreplay:
|
1999-04-16 03:35:26 +02:00
|
|
|
|
|
|
|
(gdb) target remote host:port
|
|
|
|
|
2010-05-02 18:10:03 +02:00
|
|
|
Repeat the same sequence of user commands to GDB that you gave in the
|
|
|
|
original debug session. GDB should not be able to tell that it is talking
|
|
|
|
to GDBreplay rather than a real target, all other things being equal. Note
|
|
|
|
that GDBreplay echos the command lines to stderr, as well as the contents of
|
|
|
|
the packets it sends and receives. The last command echoed by GDBreplay is
|
|
|
|
the next command that needs to be typed to GDB to continue the session in
|
1999-04-16 03:35:26 +02:00
|
|
|
sync with the original session.
|