This is the mail archive of the gdb-patches@sourceware.org mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

[patch] Sort threads for thread apply all (bt)


Hi,

downstream Fedora request:
	Please make it easier to find the backtrace of the crashing thread
	https://bugzilla.redhat.com/show_bug.cgi?id=1024504

Currently after loading a core file GDB prints:

Core was generated by `./threadcrash1'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0x000000000040062f in start (arg=0x0) at threadcrash1.c:8
8	*(volatile int *)0=0;
(gdb) _

there is nowhere seen which of the threads had crashed.  In reality GDB always
numbers that thread as #1 and it is the current thread that time.  But after
dumping all the info into a file for later analysis it is no longer obvious.
'thread apply all bt' even puts the thread #1 to the _end_ of the output!!!

Should GDB always print after loading a core file what "thread" command would
print?
[Current thread is 1 (Thread 0x7fcbe28fe700 (LWP 15453))]

Or should the "thread" output be printed only in non-interactive mode?

Or something different?

Or is the current behavior OK as is and the tools calling GDB in batch mode
should indicate the thread #1 on their own?

------------------------------------------------------------------------------

I find maybe as good enough and with no risk of UI change flamewar to just
sort the threads by their number.  Currently they are printed as they happen
in the internal GDB list which has no advantage.  Printing thread #1 as the
first one with assumed 'thread apply all bt' (after the core file is loaded)
should make the complaint resolved I guess.

No regressions on {x86_64,x86_64-m32,i686}-fedora22pre-linux-gnu.


Jan


diff of crashing different thread in 2-threaded program:
------------------------------------------------------------------------------
-Reading symbols from /home/jkratoch/t/threadcrash1...done.
-[New LWP 15453]
-[New LWP 15446]
+Reading symbols from /home/jkratoch/t/threadcrash2...done.
+[New LWP 29285]
+[New LWP 29288]
 [Thread debugging using libthread_db enabled]
 Using host libthread_db library "/lib64/libthread_db.so.1".
-Core was generated by `./threadcrash1'.
+Core was generated by `./threadcrash2'.
 Program terminated with signal SIGSEGV, Segmentation fault.
-#0  0x000000000040062f in start (arg=0x0) at threadcrash1.c:8
-8      *(volatile int *)0=0;
+#0  0x0000000000400684 in main () at threadcrash2.c:19
+19     *(volatile int *)0=0;
 (gdb) thread apply all bt
 
-Thread 2 (Thread 0x7fcbe2900700 (LWP 15446)):
+Thread 2 (Thread 0x7feb9c14c700 (LWP 29288)):
 Python Exception <type 'exceptions.ImportError'> No module named gdb.frames:
 #0  0x0000003424ec491d in nanosleep () at ../sysdeps/unix/syscall-template.S:81
 #1  0x0000003424ec47b4 in __sleep (seconds=0) at ../sysdeps/unix/sysv/linux/sleep.c:138
-#2  0x000000000040068a in main () at threadcrash1.c:19
+#2  0x000000000040062a in start (arg=0x0) at threadcrash2.c:7
+#3  0x000000342560752a in start_thread (arg=0x7feb9c14c700) at pthread_create.c:310
+#4  0x0000003424f0079d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:109
 
-Thread 1 (Thread 0x7fcbe28fe700 (LWP 15453)):
+Thread 1 (Thread 0x7feb9c14e700 (LWP 29285)):
 Python Exception <type 'exceptions.ImportError'> No module named gdb.frames:
-#0  0x000000000040062f in start (arg=0x0) at threadcrash1.c:8
-#1  0x000000342560752a in start_thread (arg=0x7fcbe28fe700) at pthread_create.c:310
-#2  0x0000003424f0079d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:109
+#0  0x0000000000400684 in main () at threadcrash2.c:19
 (gdb) thread
-[Current thread is 1 (Thread 0x7fcbe28fe700 (LWP 15453))]
+[Current thread is 1 (Thread 0x7feb9c14e700 (LWP 29285))]
 (gdb) q
gdb/ChangeLog
2015-01-15  Jan Kratochvil  <jan.kratochvil@redhat.com>

	* thread.c (tp_array_compar): New function.
	(thread_apply_all_command): Sort tp_array using it.

diff --git a/gdb/thread.c b/gdb/thread.c
index ed20fbe..cdab5d8 100644
--- a/gdb/thread.c
+++ b/gdb/thread.c
@@ -1382,6 +1382,17 @@ make_cleanup_restore_current_thread (void)
 			    restore_current_thread_cleanup_dtor);
 }
 
+/* Sort an array for struct thread_info pointers by their ascending NUM.  */
+
+static int
+tp_array_compar (const void *ap_voidp, const void *bp_voidp)
+{
+  const struct thread_info *const *ap = ap_voidp;
+  const struct thread_info *const *bp = bp_voidp;
+
+  return ((*ap)->num > (*bp)->num) - ((*ap)->num < (*bp)->num);
+}
+
 /* Apply a GDB command to a list of threads.  List syntax is a whitespace
    seperated list of numbers, or ranges, or the keyword `all'.  Ranges consist
    of two numbers seperated by a hyphen.  Examples:
@@ -1431,6 +1442,8 @@ thread_apply_all_command (char *cmd, int from_tty)
           i++;
         }
 
+      qsort (tp_array, i, sizeof (*tp_array), tp_array_compar);
+
       make_cleanup (set_thread_refcount, &ta_cleanup);
 
       for (k = 0; k != i; k++)

Attachment: threadcrash1.c
Description: Text document

Attachment: threadcrash2.c
Description: Text document


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]