Go to the first, previous, next, last section, table of contents.
To debug a program running on another machine (the debugging
target machine), you must first arrange for all the usual
prerequisites for the program to run by itself. For example, for a C
program, you need:
-
A startup routine to set up the C runtime environment; these usually
have a name like `crt0'. The startup routine may be supplied by
your hardware supplier, or you may have to write your own.
-
You probably need a C subroutine library to support your program's
subroutine calls, notably managing input and output.
-
A way of getting your program to the other machine--for example, a
download program. These are often supplied by the hardware
manufacturer, but you may have to write your own from hardware
documentation.
The next step is to arrange for your program to use a serial port to
communicate with the machine where GDB is running (the host
machine). In general terms, the scheme looks like this:
- On the host,
-
GDB already understands how to use this protocol; when everything
else is set up, you can simply use the `target remote' command
(see section Specifying a Debugging Target).
- On the target,
-
you must link with your program a few special-purpose subroutines that
implement the GDB remote serial protocol. The file containing these
subroutines is called a debugging stub.
On certain remote targets, you can use an auxiliary program
gdbserver
instead of linking a stub into your program.
See section Using the gdbserver
program, for details.
The debugging stub is specific to the architecture of the remote
machine; for example, use `sparc-stub.c' to debug programs on
SPARC boards.
These working remote stubs are distributed with GDB:
i386-stub.c
-
For Intel 386 and compatible architectures.
m68k-stub.c
-
For Motorola 680x0 architectures.
sh-stub.c
-
For Hitachi SH architectures.
sparc-stub.c
-
For SPARC architectures.
sparcl-stub.c
-
For Fujitsu SPARCLITE architectures.
The `README' file in the GDB distribution may list other
recently added stubs.
Go to the first, previous, next, last section, table of contents.