aboutsummaryrefslogtreecommitdiff
path: root/gdbserver/linux-amd64-ipa.cc
diff options
context:
space:
mode:
Diffstat (limited to 'gdbserver/linux-amd64-ipa.cc')
-rw-r--r--gdbserver/linux-amd64-ipa.cc43
1 files changed, 8 insertions, 35 deletions
diff --git a/gdbserver/linux-amd64-ipa.cc b/gdbserver/linux-amd64-ipa.cc
index df5e6ac..6f4ce6f 100644
--- a/gdbserver/linux-amd64-ipa.cc
+++ b/gdbserver/linux-amd64-ipa.cc
@@ -164,47 +164,21 @@ supply_static_tracepoint_registers (struct regcache *regcache,
#endif /* HAVE_UST */
-#if !defined __ILP32__
-/* Map the tdesc index to xcr0 mask. */
-static uint64_t idx2mask[X86_TDESC_LAST] = {
- X86_XSTATE_X87_MASK,
- X86_XSTATE_SSE_MASK,
- X86_XSTATE_AVX_MASK,
- X86_XSTATE_MPX_MASK,
- X86_XSTATE_AVX_MPX_MASK,
- X86_XSTATE_AVX_AVX512_MASK,
- X86_XSTATE_AVX_MPX_AVX512_PKU_MASK,
-};
-#endif
-
/* Return target_desc to use for IPA, given the tdesc index passed by
gdbserver. */
const struct target_desc *
get_ipa_tdesc (int idx)
{
- if (idx >= X86_TDESC_LAST)
- {
- internal_error ("unknown ipa tdesc index: %d", idx);
- }
+ uint64_t xcr0 = x86_linux_tdesc_idx_to_xcr0 (idx);
#if defined __ILP32__
- switch (idx)
- {
- case X86_TDESC_SSE:
- return amd64_linux_read_description (X86_XSTATE_SSE_MASK, true);
- case X86_TDESC_AVX:
- return amd64_linux_read_description (X86_XSTATE_AVX_MASK, true);
- case X86_TDESC_AVX_AVX512:
- return amd64_linux_read_description (X86_XSTATE_AVX_AVX512_MASK, true);
- default:
- break;
- }
+ bool is_x32 = true;
#else
- return amd64_linux_read_description (idx2mask[idx], false);
+ bool is_x32 = false;
#endif
- internal_error ("unknown ipa tdesc index: %d", idx);
+ return amd64_linux_read_description (xcr0, is_x32);
}
/* Allocate buffer for the jump pads. The branch instruction has a
@@ -272,11 +246,10 @@ void
initialize_low_tracepoint (void)
{
#if defined __ILP32__
- amd64_linux_read_description (X86_XSTATE_SSE_MASK, true);
- amd64_linux_read_description (X86_XSTATE_AVX_MASK, true);
- amd64_linux_read_description (X86_XSTATE_AVX_AVX512_MASK, true);
+ for (int i = 0; i < x86_linux_x32_tdesc_count (); i++)
+ amd64_linux_read_description (x86_linux_tdesc_idx_to_xcr0 (i), true);
#else
- for (auto i = 0; i < X86_TDESC_LAST; i++)
- amd64_linux_read_description (idx2mask[i], false);
+ for (int i = 0; i < x86_linux_amd64_tdesc_count (); i++)
+ amd64_linux_read_description (x86_linux_tdesc_idx_to_xcr0 (i), false);
#endif
}