diff options
author | Yao Qi <yao.qi@linaro.org> | 2017-09-05 09:54:54 +0100 |
---|---|---|
committer | Yao Qi <yao.qi@linaro.org> | 2017-09-05 09:54:54 +0100 |
commit | 22916b0786336394bf84f68ba71875ac3cd48fea (patch) | |
tree | d33017acd70368911aafd35d32af46f61c2a358d /gdb/arch | |
parent | 0854b7b1878dc9f8b8519e2efed605acecc14745 (diff) | |
download | binutils-22916b0786336394bf84f68ba71875ac3cd48fea.zip binutils-22916b0786336394bf84f68ba71875ac3cd48fea.tar.gz binutils-22916b0786336394bf84f68ba71875ac3cd48fea.tar.bz2 |
Convert the rest x86 target descriptions
This patch changes the rest of x86 target descriptions in GDB and
GDBserver.
gdb:
2017-09-05 Yao Qi <yao.qi@linaro.org>
* amd64-tdep.c (amd64_target_description): Create target
descriptions.
(_initialize_amd64_tdep): Don't call functions
initialize_tdesc_amd64_*. Add self tests.
* arch/amd64.c (amd64_create_target_description): Add parameter
is_linux. Call set_tdesc_osabi if is_linux is true.
* arch/amd64.h (amd64_create_target_description): Update the
declaration.
* arch/i386.c (i386_create_target_description): Add parameter
is_linux. Call set_tdesc_osabi if is_linux is true.
* arch/i386.h (i386_create_target_description): Update
declaration.
* configure.tgt: Add i386.o to gdb_target_obs.
* features/Makefile (XMLTOC): Remove i386/*.xml.
* features/i386/amd64-avx-avx512.c: Remove.
* features/i386/amd64-avx-mpx-avx512-pku.c: Remove.
* features/i386/amd64-avx-mpx.c: Remove.
* features/i386/amd64-avx.c: Remove.
* features/i386/amd64-mpx.c: Remove.
* features/i386/amd64.c: Remove.
* features/i386/i386-avx-avx512.c: Remove.
* features/i386/i386-avx-mpx-avx512-pku.c: Remove.
* features/i386/i386-avx-mpx.c: Remove.
* features/i386/i386-avx.c: Remove.
* features/i386/i386-mmx.c: Remove.
* features/i386/i386-mpx.c: Remove.
* features/i386/i386.c: Remove.
* i386-tdep.c: Don't include features/i386/i386*.c., include
target-descriptions.h and arch/i386.h.
(i386_target_description): Create target descriptions.
(i386_gdbarch_init): Don't call initialize_tdesc_i386_*
functions. Do self tests.
gdb/gdbserver:
2017-09-05 Yao Qi <yao.qi@linaro.org>
* configure.srv (srv_i386_regobj): Remove.
(srv_amd64_regobj): Remove.
(srv_regobj): Set it to "" for x86 non-linux targets.
* linux-x86-tdesc.c (i386_linux_read_description):
* lynx-i386-low.c: Include x86-xstate.h and arch/i386.h.
(init_registers_i386): Remove the declaration.
(tdesc_i386): Remove the declaration.
(lynx_i386_arch_setup): Call i386_create_target_description.
* nto-x86-low.c: Likewise.
* win32-i386-low.c [__x86_64__]: include arch/amd64.h.
[!__x86_64__]: include arch/i386.h.
(i386_arch_setup) [__x86_64__]: Call amd64_create_target_description.
Diffstat (limited to 'gdb/arch')
-rw-r--r-- | gdb/arch/amd64.c | 11 | ||||
-rw-r--r-- | gdb/arch/amd64.h | 3 | ||||
-rw-r--r-- | gdb/arch/i386.c | 8 | ||||
-rw-r--r-- | gdb/arch/i386.h | 2 |
4 files changed, 15 insertions, 9 deletions
diff --git a/gdb/arch/amd64.c b/gdb/arch/amd64.c index 626733d..30c73e6 100644 --- a/gdb/arch/amd64.c +++ b/gdb/arch/amd64.c @@ -31,17 +31,19 @@ #include "../features/i386/x32-core.c" /* Create amd64 target descriptions according to XCR0. If IS_X32 is - true, create the x32 ones. */ + true, create the x32 ones. If IS_LINUX is true, create target + descriptions for Linux. */ target_desc * -amd64_create_target_description (uint64_t xcr0, bool is_x32) +amd64_create_target_description (uint64_t xcr0, bool is_x32, bool is_linux) { target_desc *tdesc = allocate_target_description (); #ifndef IN_PROCESS_AGENT set_tdesc_architecture (tdesc, is_x32 ? "i386:x64-32" : "i386:x86-64"); - set_tdesc_osabi (tdesc, "GNU/Linux"); + if (is_linux) + set_tdesc_osabi (tdesc, "GNU/Linux"); #endif long regnum = 0; @@ -52,7 +54,8 @@ amd64_create_target_description (uint64_t xcr0, bool is_x32) regnum = create_feature_i386_64bit_core (tdesc, regnum); regnum = create_feature_i386_64bit_sse (tdesc, regnum); - regnum = create_feature_i386_64bit_linux (tdesc, regnum); + if (is_linux) + regnum = create_feature_i386_64bit_linux (tdesc, regnum); regnum = create_feature_i386_64bit_segments (tdesc, regnum); if (xcr0 & X86_XSTATE_AVX) diff --git a/gdb/arch/amd64.h b/gdb/arch/amd64.h index 0821a7c..22c63d2 100644 --- a/gdb/arch/amd64.h +++ b/gdb/arch/amd64.h @@ -18,4 +18,5 @@ #include "tdesc.h" #include <stdint.h> -target_desc *amd64_create_target_description (uint64_t xcr0, bool is_x32); +target_desc *amd64_create_target_description (uint64_t xcr0, bool is_x32, + bool is_linux); diff --git a/gdb/arch/i386.c b/gdb/arch/i386.c index 60cf63b..7d71506 100644 --- a/gdb/arch/i386.c +++ b/gdb/arch/i386.c @@ -31,13 +31,14 @@ /* Create i386 target descriptions according to XCR0. */ target_desc * -i386_create_target_description (uint64_t xcr0) +i386_create_target_description (uint64_t xcr0, bool is_linux) { target_desc *tdesc = allocate_target_description (); #ifndef IN_PROCESS_AGENT set_tdesc_architecture (tdesc, "i386"); - set_tdesc_osabi (tdesc, "GNU/Linux"); + if (is_linux) + set_tdesc_osabi (tdesc, "GNU/Linux"); #endif long regnum = 0; @@ -48,7 +49,8 @@ i386_create_target_description (uint64_t xcr0) if (xcr0 & X86_XSTATE_SSE) regnum = create_feature_i386_32bit_sse (tdesc, regnum); - regnum = create_feature_i386_32bit_linux (tdesc, regnum); + if (is_linux) + regnum = create_feature_i386_32bit_linux (tdesc, regnum); if (xcr0 & X86_XSTATE_AVX) regnum = create_feature_i386_32bit_avx (tdesc, regnum); diff --git a/gdb/arch/i386.h b/gdb/arch/i386.h index 0163372..c44e24b 100644 --- a/gdb/arch/i386.h +++ b/gdb/arch/i386.h @@ -18,4 +18,4 @@ #include "tdesc.h" #include <stdint.h> -target_desc *i386_create_target_description (uint64_t xcr0); +target_desc *i386_create_target_description (uint64_t xcr0, bool is_linux); |