From: Tom de Vries Date: Fri, 15 Jul 2022 16:46:03 +0000 (+0200) Subject: [gdb/symtab] Fix race condition in just_read_cus X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c2ae16cc58b64e21a6b993544943fb9612e904a2;p=thirdparty%2Fbinutils-gdb.git [gdb/symtab] Fix race condition in just_read_cus Race condition between: ... Read of size 8 at 0x7b640001f2c8 by thread T1: #0 std::vector >::push_back(dwarf2_per_cu_data* const&) /usr/include/c++/12/bits/stl_vector.h:1278 (gdb+0x888ad6) #1 process_full_comp_unit gdb/dwarf2/read.c:8451 (gdb+0x8397d0) #2 process_queue_item gdb/dwarf2/read.c:7592 (gdb+0x8359f5) ... and: ... Previous write of size 8 at 0x7b640001f2c8 by main thread: #0 std::vector >::push_back(dwarf2_per_cu_data* const&) /usr/include/c++/12/bits/stl_vector.h:1283 (gdb+0x888b52) #1 process_full_comp_unit gdb/dwarf2/read.c:8451 (gdb+0x8397d0) #2 process_queue_item gdb/dwarf2/read.c:7592 (gdb+0x8359f5) ... Fix this by doing the just_read_cus push_back in a lock. --- diff --git a/gdb/dwarf2/read.c b/gdb/dwarf2/read.c index 11ba01c6b01..66f3ca01caf 100644 --- a/gdb/dwarf2/read.c +++ b/gdb/dwarf2/read.c @@ -8463,8 +8463,14 @@ process_full_comp_unit (dwarf2_cu *cu, enum language pretend_language) per_objfile->set_symtab (cu->per_cu, cust); - /* Push it for inclusion processing later. */ - per_objfile->per_bfd->just_read_cus.push_back (cu->per_cu); +#if CXX_STD_THREAD + { + static std::mutex just_read_cus_lock; + std::lock_guard guard (just_read_cus_lock); +#endif + /* Push it for inclusion processing later. */ + per_objfile->per_bfd->just_read_cus.push_back (cu->per_cu); + } /* Not needed any more. */ cu->reset_builder ();