diff options
author | Tom de Vries <tdevries@suse.de> | 2023-08-02 23:17:35 +0200 |
---|---|---|
committer | Tom de Vries <tdevries@suse.de> | 2023-08-02 23:17:35 +0200 |
commit | c082d7f58efad2a3e1edbedc34853b37f2f68c0d (patch) | |
tree | fe196ad77a2c16ee32fa83c713b45a1533d85375 /gdb/gdb.c | |
parent | 3c3e54d7b5f7da003292710fe810e670d45832d8 (diff) | |
download | gdb-c082d7f58efad2a3e1edbedc34853b37f2f68c0d.zip gdb-c082d7f58efad2a3e1edbedc34853b37f2f68c0d.tar.gz gdb-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.c | 7 |
1 files changed, 7 insertions, 0 deletions
@@ -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); |