aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTom Hacohen <tom@stosb.com>2013-11-05 15:50:23 +0000
committerTom Hacohen <tom@stosb.com>2013-11-05 15:54:15 +0000
commit18cbd6f59a9c004dc1fe15d17331b3e23e8a6582 (patch)
treefae8be359aa95c7245a5422685b7854b8b790f4f
parentcheck e passes distckec and set up a 0.18 alpha1 (diff)
downloadenlightenment-18cbd6f59a9c004dc1fe15d17331b3e23e8a6582.tar.gz
wsod: Fixed gdb hangs when generating backtraces.
After a long and hard battle with the gods of bugs I finally fixed this stupid hang. I had to dig into the gdb source code, and gdb the hell out of gdb, but it's now solved. First of all, we should call gdb with -batch which exits automatically. This however is not enough to fix it. The bug was that gdb was haning while trying to set attributes on stdin because it was waiting for input. This is obviously problematic when running in non-interactive mode, so I had to pipe /dev/zero to stdin to fix it. While at it, I also fixed the piping of stdout and stderr to be nicer.
-rw-r--r--ChangeLog3
-rw-r--r--NEWS1
-rw-r--r--src/bin/e_sys_main.c3
3 files changed, 6 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 86c6cff43..f49d0c8b0 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,6 @@
+2013-11-05 Tom Hacohen
+ * wsod: Fixed gdb hangs when generating backtraces.
+
2013-10-07 Mike Blumenkrantz
* removed "raise on focus" config option
diff --git a/NEWS b/NEWS
index dcb8ec509..d06bd69bd 100644
--- a/NEWS
+++ b/NEWS
@@ -234,3 +234,4 @@ Fixes:
* fixed bug where new files could not be created repeatedly
* fixed filemanager spring window closing when dragging from desktop
* fixed catching XWindow closes during DND operations on those windows
+ * wsod: Fixed gdb hangs when generating backtraces.
diff --git a/src/bin/e_sys_main.c b/src/bin/e_sys_main.c
index b48f1c08b..edbb70da4 100644
--- a/src/bin/e_sys_main.c
+++ b/src/bin/e_sys_main.c
@@ -168,10 +168,11 @@ main(int argc,
snprintf(buffer, 4096,
"%s --pid=%i "
+ "-batch "
"-ex 'set logging file %s' "
"-ex 'set logging on' "
"-ex 'thread apply all backtrace full' "
- "-ex detach -ex quit > /dev/null 2> /dev/null",
+ "-ex detach &> /dev/null < /dev/zero",
cmd,
pid,
output ?: "e-output.txt");