From 684943d213b461a6a84ae67a9b8fcae5a28f007d Mon Sep 17 00:00:00 2001 From: John Baldwin Date: Tue, 3 May 2022 16:05:10 -0700 Subject: [PATCH] Fetch the NT_ARM_TLS register set for native FreeBSD/arm processes. This permits resolving TLS variables. --- gdb/arm-fbsd-nat.c | 52 +++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 51 insertions(+), 1 deletion(-) diff --git a/gdb/arm-fbsd-nat.c b/gdb/arm-fbsd-nat.c index c32924de735..a306e1e2ee0 100644 --- a/gdb/arm-fbsd-nat.c +++ b/gdb/arm-fbsd-nat.c @@ -18,13 +18,17 @@ along with this program. If not, see . */ #include "defs.h" +#include "inferior.h" #include "target.h" +#include "elf/common.h" + #include #include #include #include "fbsd-nat.h" +#include "arm-tdep.h" #include "arm-fbsd-tdep.h" #include "inf-ptrace.h" @@ -49,6 +53,27 @@ arm_fbsd_nat_target::fetch_registers (struct regcache *regcache, int regnum) fetch_register_set (regcache, regnum, PT_GETVFPREGS, &arm_fbsd_vfpregset); #endif +#ifdef PT_GETREGSET + gdbarch *gdbarch = regcache->arch (); + arm_gdbarch_tdep *tdep = (arm_gdbarch_tdep *) gdbarch_tdep (gdbarch); + + if (tdep->tls_regnum > 0) + { + const struct regcache_map_entry arm_fbsd_tlsregmap[] = + { + { 1, tdep->tls_regnum, 4 }, + { 0 } + }; + + const struct regset arm_fbsd_tlsregset = + { + arm_fbsd_tlsregmap, + regcache_supply_regset, regcache_collect_regset + }; + + fetch_regset (regcache, regnum, NT_ARM_TLS, &arm_fbsd_tlsregset); + } +#endif } /* Store register REGNUM back into the inferior. If REGNUM is -1, do @@ -63,6 +88,27 @@ arm_fbsd_nat_target::store_registers (struct regcache *regcache, int regnum) store_register_set (regcache, regnum, PT_GETVFPREGS, PT_SETVFPREGS, &arm_fbsd_vfpregset); #endif +#ifdef PT_GETREGSET + gdbarch *gdbarch = regcache->arch (); + arm_gdbarch_tdep *tdep = (arm_gdbarch_tdep *) gdbarch_tdep (gdbarch); + + if (tdep->tls_regnum > 0) + { + const struct regcache_map_entry arm_fbsd_tlsregmap[] = + { + { 1, tdep->tls_regnum, 4 }, + { 0 } + }; + + const struct regset arm_fbsd_tlsregset = + { + arm_fbsd_tlsregmap, + regcache_supply_regset, regcache_collect_regset + }; + + store_regset (regcache, regnum, NT_ARM_TLS, &arm_fbsd_tlsregset); + } +#endif } /* Implement the to_read_description method. */ @@ -71,8 +117,12 @@ const struct target_desc * arm_fbsd_nat_target::read_description () { const struct target_desc *desc; + bool tls = false; - desc = arm_fbsd_read_description_auxv (this, false); +#ifdef PT_GETREGSET + tls = have_regset (inferior_ptid, NT_ARM_TLS) != 0; +#endif + desc = arm_fbsd_read_description_auxv (this, tls); if (desc == NULL) desc = this->beneath ()->read_description (); return desc; -- 2.30.2