Cache the Thread Local Base pointer type in the gdbarch
authorHannes Domani <ssbssa@yahoo.de>
Sun, 9 Feb 2020 16:37:58 +0000 (17:37 +0100)
committerHannes Domani <ssbssa@yahoo.de>
Wed, 12 Feb 2020 16:02:35 +0000 (17:02 +0100)
gdb/ChangeLog:

2020-02-12  Hannes Domani  <ssbssa@yahoo.de>

* windows-tdep.c (struct windows_gdbarch_data): Add tib_ptr_type.
(windows_get_tlb_type): Use windows_gdbarch_data->tib_ptr_type.

gdb/ChangeLog
gdb/windows-tdep.c

index 43fe4de68576abb3ef94cebd24dd406fda41593d..6629b8a1503029b2abd1c83f5b5d7402c2af25b3 100644 (file)
@@ -1,3 +1,8 @@
+2020-02-12  Hannes Domani  <ssbssa@yahoo.de>
+
+       * windows-tdep.c (struct windows_gdbarch_data): Add tib_ptr_type.
+       (windows_get_tlb_type): Use windows_gdbarch_data->tib_ptr_type.
+
 2020-02-11  Tom Tromey  <tom@tromey.com>
 
        * psymtab.h: Update comment.
index e9787887a4af87c0faf547b916ecf71feea72dec..6eef3fbd9694f6d1004c55d4672528d0a76900ea 100644 (file)
@@ -158,6 +158,7 @@ static struct gdbarch_data *windows_gdbarch_data_handle;
 struct windows_gdbarch_data
 {
   struct type *siginfo_type;
+  struct type *tib_ptr_type; /* Type of thread information block */
 };
 
 /* Allocate windows_gdbarch_data for an arch.  */
@@ -182,8 +183,6 @@ get_windows_gdbarch_data (struct gdbarch *gdbarch)
 static struct type *
 windows_get_tlb_type (struct gdbarch *gdbarch)
 {
-  static struct gdbarch *last_gdbarch = NULL;
-  static struct type *last_tlb_type = NULL;
   struct type *dword_ptr_type, *dword32_type, *void_ptr_type;
   struct type *peb_ldr_type, *peb_ldr_ptr_type;
   struct type *peb_type, *peb_ptr_type, *list_type;
@@ -192,10 +191,11 @@ windows_get_tlb_type (struct gdbarch *gdbarch)
   struct type *word_type, *wchar_type, *wchar_ptr_type;
   struct type *uni_str_type, *rupp_type, *rupp_ptr_type;
 
-  /* Do not rebuild type if same gdbarch as last time.  */
-  if (last_tlb_type && last_gdbarch == gdbarch)
-    return last_tlb_type;
-  
+  windows_gdbarch_data *windows_gdbarch_data
+    = get_windows_gdbarch_data (gdbarch);
+  if (windows_gdbarch_data->tib_ptr_type != nullptr)
+    return windows_gdbarch_data->tib_ptr_type;
+
   dword_ptr_type = arch_integer_type (gdbarch, gdbarch_ptr_bit (gdbarch),
                                 1, "DWORD_PTR");
   dword32_type = arch_integer_type (gdbarch, 32,
@@ -365,8 +365,7 @@ windows_get_tlb_type (struct gdbarch *gdbarch)
                            NULL);
   TYPE_TARGET_TYPE (tib_ptr_type) = tib_type;
 
-  last_tlb_type = tib_ptr_type;
-  last_gdbarch = gdbarch;
+  windows_gdbarch_data->tib_ptr_type = tib_ptr_type;
 
   return tib_ptr_type;
 }