patches/gdb/6.3/800-debian_linux-use-underscore-exit.patch
author "Yann E. MORIN" <yann.morin.1998@anciens.enib.fr>
Sun May 20 13:48:26 2007 +0000 (2007-05-20)
changeset 112 ea15433daba0
permissions -rw-r--r--
Ah! I finally have a progress bar that doesn't stall the build!
- pipe size in Linux is only 8*512=4096 bytes
- pipe size is not setable
- when the feeding process spits out data faster than the eating
process can read it, then the feeding process stalls after 4KiB
of data sent to the pipe
- for us, the progress bar would spawn a sub-shell every line,
and the sub-shell would in turn spawn a 'date' command.
Which was sloooww as hell, and would cause some kind of a
starvation: the pipe was full most of the time, and the
feeding process was stalled all this time.

Now, we use internal variables and a little hack based onan offset
to determine the elapsed time. Much faster this way, but still
CPU-intensive.
yann@96
     1
Status: committed upstream after 6.3.  Fixes some terminal mangling in
yann@96
     2
gdbtui.
yann@96
     3
yann@96
     4
2004-12-04  Daniel Jacobowitz  <dan@debian.org>
yann@96
     5
yann@96
     6
	PR tui/1703
yann@96
     7
	* linux-nat.c (linux_tracefork_child): Use _exit instead of exit.
yann@96
     8
	Suggested by Joshua Neuheisel.
yann@96
     9
yann@96
    10
Index: gdb-6.3/gdb/linux-nat.c
yann@96
    11
===================================================================
yann@96
    12
--- gdb-6.3.orig/gdb/linux-nat.c	2004-12-08 18:22:04.996973094 -0500
yann@96
    13
+++ gdb-6.3/gdb/linux-nat.c	2004-12-08 18:22:20.386956067 -0500
yann@96
    14
@@ -147,7 +147,7 @@ linux_tracefork_child (void)
yann@96
    15
   ptrace (PTRACE_TRACEME, 0, 0, 0);
yann@96
    16
   kill (getpid (), SIGSTOP);
yann@96
    17
   fork ();
yann@96
    18
-  exit (0);
yann@96
    19
+  _exit (0);
yann@96
    20
 }
yann@96
    21
 
yann@96
    22
 /* Wrapper function for waitpid which handles EINTR.  */