From: John Baldwin Date: Tue, 12 Mar 2019 20:39:02 +0000 (-0700) Subject: Handle an edge case for minisym TLS variable lookups. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=df22c1e5d53c38f38bce6072bb46de240f9e0e2b;p=binutils-gdb.git Handle an edge case for minisym TLS variable lookups. If a TLS variable is provided by a minisym from a separate debug file, the separate debug file is passed to gdbarch_fetch_tls_load_module_address. However, the object files stored in the shared object list are the original object files, not the separate debug object files. In this case, svr4_fetch_objfile_link_map was failing to find the link map entry since the debug object file is not in its internal list, only the original object file. gdb/ChangeLog: * solib-svr4.c (svr4_fetch_objfile_link_map): Look for objfile->separate_debug_objfile_backlink if not NULL. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index c91e9753091..f0254525463 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2019-03-12 John Baldwin + + * solib-svr4.c (svr4_fetch_objfile_link_map): Look for + objfile->separate_debug_objfile_backlink if not NULL. + 2019-03-12 John Baldwin * amd64-bsd-nat.c (amd64bsd_fetch_inferior_registers): Use diff --git a/gdb/solib-svr4.c b/gdb/solib-svr4.c index 84693c17666..14a471b6dc0 100644 --- a/gdb/solib-svr4.c +++ b/gdb/solib-svr4.c @@ -1551,6 +1551,11 @@ svr4_fetch_objfile_link_map (struct objfile *objfile) if (objfile == symfile_objfile) return info->main_lm_addr; + /* If OBJFILE is a separate debug object file, look for the + original object file. */ + if (objfile->separate_debug_objfile_backlink != NULL) + objfile = objfile->separate_debug_objfile_backlink; + /* The other link map addresses may be found by examining the list of shared libraries. */ for (so = master_so_list (); so; so = so->next)