aboutsummaryrefslogtreecommitdiff
path: root/gdb/linux-thread-db.c
diff options
context:
space:
mode:
authorPaul Pluzhnikov <ppluzhnikov@google.com>2009-07-16 19:47:43 +0000
committerPaul Pluzhnikov <ppluzhnikov@google.com>2009-07-16 19:47:43 +0000
commit456b0e2407650e5149308fb3fe21f750f9e32e1d (patch)
tree527cf43ca90596d322e134f32ed803f5c6554a46 /gdb/linux-thread-db.c
parent0aaaf7c3ef758c804f78ecab8dc36f247c4651d9 (diff)
downloadfsf-binutils-gdb-456b0e2407650e5149308fb3fe21f750f9e32e1d.zip
fsf-binutils-gdb-456b0e2407650e5149308fb3fe21f750f9e32e1d.tar.gz
fsf-binutils-gdb-456b0e2407650e5149308fb3fe21f750f9e32e1d.tar.bz2
2007-07-16 Paul Pluzhnikov <ppluzhnikov@google.com>
* linux-thread-db.c (thread_db_find_new_threads_silently): New function. (try_thread_db_load_1): Call it.
Diffstat (limited to 'gdb/linux-thread-db.c')
-rw-r--r--gdb/linux-thread-db.c27
1 files changed, 26 insertions, 1 deletions
diff --git a/gdb/linux-thread-db.c b/gdb/linux-thread-db.c
index cea4541..035d3c2 100644
--- a/gdb/linux-thread-db.c
+++ b/gdb/linux-thread-db.c
@@ -588,6 +588,25 @@ enable_thread_event_reporting (void)
}
}
+/* Same as thread_db_find_new_threads_1, but silently ignore errors. */
+
+static void
+thread_db_find_new_threads_silently (ptid_t ptid)
+{
+ volatile struct gdb_exception except;
+
+ TRY_CATCH (except, RETURN_MASK_ERROR)
+ {
+ thread_db_find_new_threads_1 (ptid);
+ }
+
+ if (except.reason < 0 && info_verbose)
+ {
+ exception_fprintf (gdb_stderr, except,
+ "Warning: thread_db_find_new_threads_silently: ");
+ }
+}
+
/* Lookup a library in which given symbol resides.
Note: this is looking in GDB process, not in the inferior.
Returns library name, or NULL. */
@@ -705,7 +724,13 @@ try_thread_db_load_1 (struct thread_db_info *info)
push_target (&thread_db_ops);
enable_thread_event_reporting ();
- thread_db_find_new_threads_1 (inferior_ptid);
+
+ /* There appears to be a bug glibc-2.3.6: call to td_thr_get_info fails
+ with TD_ERR for statically linked executables if td_thr_get_info is
+ called before glibc has initialized itself. Silently ignore such
+ errors. */
+
+ thread_db_find_new_threads_silently (inferior_ptid);
return 1;
}