diff options
author | Jim Kingdon <jkingdon@engr.sgi.com> | 1995-01-23 22:27:49 +0000 |
---|---|---|
committer | Jim Kingdon <jkingdon@engr.sgi.com> | 1995-01-23 22:27:49 +0000 |
commit | 1b0c5a4fbb7352ff544f57c3b3acaf853c3f706b (patch) | |
tree | 9663ea163aea22002ab92c0648c104b65d115883 /gdb/doc/gdb.texinfo | |
parent | 73433384365b8609582679d37c870a37bcd3e80b (diff) | |
download | gdb-1b0c5a4fbb7352ff544f57c3b3acaf853c3f706b.zip gdb-1b0c5a4fbb7352ff544f57c3b3acaf853c3f706b.tar.gz gdb-1b0c5a4fbb7352ff544f57c3b3acaf853c3f706b.tar.bz2 |
* gdb.texinfo (Processes): New node.
Diffstat (limited to 'gdb/doc/gdb.texinfo')
-rw-r--r-- | gdb/doc/gdb.texinfo | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/gdb/doc/gdb.texinfo b/gdb/doc/gdb.texinfo index 5db9253..f727326 100644 --- a/gdb/doc/gdb.texinfo +++ b/gdb/doc/gdb.texinfo @@ -1400,6 +1400,7 @@ already running process, or kill a child process. * Kill Process:: Killing the child process * Process Information:: Additional process information * Threads:: Debugging programs with multiple threads +* Processes:: Debugging programs with multiple processes @end ifclear @end menu @@ -1985,6 +1986,30 @@ programs with multiple threads. watchpoints in programs with multiple threads. @end ifclear +@node Processes +@section Debugging programs with multiple processes + +@cindex fork, debugging programs which call +@cindex multiple processes +@cindex processes, multiple +@value{GDBN} has no special support for debugging programs which create +additional processes using the @code{fork} function. When a program +forks, @value{GDBN} will continue to debug the parent process and the +child process will run unimpeded. If you have set a breakpoint in any +code which the child then executes, the child will get a @code{SIGTRAP} +signal which (unless it catches the signal) will cause it to terminate. + +However, if you want to debug the child process there is a workaround +which isn't too painful. Put a call to @code{sleep} in the code which +the child process executes after the fork. It may be useful to sleep +only if a certain environment variable is set, or a certain file exists, +so that the delay need not occur when you don't want to run @value{GDBN} +on the child. While the child is sleeping, use the @code{ps} program to +get its process ID. Then tell @value{GDBN} (a new invocation of +@value{GDBN} if you are also debugging the parent process) to attach to +the child process (see @ref{Attach}). From that point on you can debug +the child process just like any other process which you attached to. + @node Stopping @chapter Stopping and Continuing |