aboutsummaryrefslogtreecommitdiff
path: root/gdb/gdb.c
diff options
context:
space:
mode:
authorTom de Vries <tdevries@suse.de>2023-08-02 23:17:35 +0200
committerTom de Vries <tdevries@suse.de>2023-08-02 23:17:35 +0200
commitc082d7f58efad2a3e1edbedc34853b37f2f68c0d (patch)
treefe196ad77a2c16ee32fa83c713b45a1533d85375 /gdb/gdb.c
parent3c3e54d7b5f7da003292710fe810e670d45832d8 (diff)
downloadbinutils-c082d7f58efad2a3e1edbedc34853b37f2f68c0d.zip
binutils-c082d7f58efad2a3e1edbedc34853b37f2f68c0d.tar.gz
binutils-c082d7f58efad2a3e1edbedc34853b37f2f68c0d.tar.bz2
[gdb] Initialize main_thread_id earlier
I wrote a patch using is_main_thread (), and found it returning false in the main thread due to main_thread_id not being initialized yet. Initialization currently takes place in _initialize_run_on_main_thread, but that's too late for earlier uses. Fix this by initializing, either: - when entering main, or - on an earlier first use. Tested on x86_64-linux. Approved-By: Tom Tromey <tom@tromey.com>
Diffstat (limited to 'gdb/gdb.c')
-rw-r--r--gdb/gdb.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/gdb/gdb.c b/gdb/gdb.c
index 71a3fd1..6e3ff07 100644
--- a/gdb/gdb.c
+++ b/gdb/gdb.c
@@ -19,10 +19,17 @@
#include "defs.h"
#include "main.h"
#include "interps.h"
+#include "run-on-main-thread.h"
int
main (int argc, char **argv)
{
+ /* The first call to is_main_thread () should be from the main thread.
+ If this is the first call, then that requirement is fulfilled here.
+ If this is not the first call, then this verifies that the first call
+ fulfilled that requirement. */
+ gdb_assert (is_main_thread ());
+
struct captured_main_args args;
memset (&args, 0, sizeof args);