Doc for gdbserver!
authorStu Grossman <grossman@cygnus>
Sat, 29 May 1993 02:31:00 +0000 (02:31 +0000)
committerStu Grossman <grossman@cygnus>
Sat, 29 May 1993 02:31:00 +0000 (02:31 +0000)
gdb/gdbserver/README [new file with mode: 0644]

diff --git a/gdb/gdbserver/README b/gdb/gdbserver/README
new file mode 100644 (file)
index 0000000..c155ce9
--- /dev/null
@@ -0,0 +1,85 @@
+                       README for GDBserver
+                         by Stu Grossman
+
+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 host 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 can communicate via
+either a serial line or a TCP connection.
+
+Usage (server (target) side):
+
+First, you will need to have a copy of the program to be debugged put onto
+the target system.  It can be stripped if you need to save space.  This is ok
+because GDBserver doesn't care about symbols, all of that stuff is taken care
+of by the GDB running on the host system.
+
+To use the server, you will need to log on to the target system, and run the
+server program.  You will need to tell it how to communicate with GDB, the
+name of the program to be debugged, and it's arguments.  For example, using a
+serial port, you might say:
+
+       target> gdbserver /dev/com1 emacs foo.txt
+
+This tells gdbserver to debug emacs with an argument of foo.txt.  The server
+will communicate with GDB via /dev/com1.  GDBserver will now wait patiently
+for 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
+now going to communicate with 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 ports on your
+system.  This same port number will also be used in the GDB `target remote'
+command, which we will discuss later.  Note that it's safe to chose a number
+that conflicts, gdbserver will just print an error message and exit.
+
+Usage (host side):
+
+You should have a copy of the target program on your host system, since GDB
+will need it to examine symbol tables and such.  You should start up GDB just
+as you normally would, with the target program as the first argument.  Ie:
+`gdb target-prog'.  After that, you will only need to know about one new
+command.  This is `target remote'.  It's argument is either a device name
+(preferably of a serial device, like /dev/ttyb), or a host:port descriptor.
+For example:
+
+       (gdb) target remote /dev/ttyb
+
+will communicate with the server via the hardware serial line /dev/ttyb, and:
+
+       (gdb) target remote the-target:2345
+
+will communicate via a TCP connection to port 2345 on host `the-target', where
+you have already started up gdbserver with the same port number.  Note that you
+must start up gdbserver prior to using the target command, otherwise you will
+get an error that looks something like `Connection refused'.
+
+Building:
+
+Currently, the only target system supported by the server is Lynx.  To build
+the server for Lynx, make a new copy of the distribution onto a disk that is
+NFS shared with the Lynx system.  Lets say that's in a directory called xyzzy.
+Then, follow these steps under the host system:
+
+       1) cd xyzzy/gdb/gdbserver
+       2) ../../configure --target i386-none-lynx
+
+When that completes, do the following on the Lynx system:
+
+       3) cd xyzzy/gdb/gdbserver
+       4) make CC=gcc
+
+It should build with only a minor complaint about NULL being redefined.  That's
+a LynxOS problem, and can be ignored.
+
+It's also possible that you may have a cross-compiler to Lynx.  In that case,
+you can skip the stuff about NFS.  You would replace steps 3 & 4 with:
+
+       make CC=lynx-target-compiler...