diff options
author | Yao Qi <yao.qi@linaro.org> | 2017-09-05 09:54:53 +0100 |
---|---|---|
committer | Yao Qi <yao.qi@linaro.org> | 2017-09-05 09:54:53 +0100 |
commit | 5f035c0716c3b6b310a736841b16088d984be917 (patch) | |
tree | 16b38d34949029002402750d155ed37cd4458a7e /gdb/gdbserver | |
parent | 0abe8a8992948559d225ff120095e42a1a6a36f4 (diff) | |
download | gdb-5f035c0716c3b6b310a736841b16088d984be917.zip gdb-5f035c0716c3b6b310a736841b16088d984be917.tar.gz gdb-5f035c0716c3b6b310a736841b16088d984be917.tar.bz2 |
Share i386-linux target description between GDB and GDBserver
The code on creating i386-linux target descriptions are quite similar
between GDB and GDBserver, so this patch moves them into a shared file
arch/i386.c. I didn't name it as i386-linux.c, because I want to reuse it
to create other i386 non-linux target descriptions later.
gdb:
2017-09-05 Yao Qi <yao.qi@linaro.org>
* Makefile.in (ALL_TARGET_OBS): Add i386.o.
(SFILES): Add arch/i386.c.
(HFILES_NO_SRCDIR): Add arch/i386.h.
* arch/i386.c: New file.
* arch/i386.h: New file.
* arch/tdesc.h (allocate_target_description): Declare.
(set_tdesc_architecture): Declare.
(set_tdesc_osabi): Declare.
* configure.tgt (i[34567]86-*-linux*): Add i386.o.
* i386-linux-tdep.c: Don't include ../features/i386/32bit-XXX.c.
include arch/i386.h.
(i386_linux_read_description): Remove code and call
i386_create_target_description.
(set_tdesc_architecture): New function.
(set_tdesc_osabi): New function.
* target-descriptions.h (allocate_target_description): Remove.
gdb/gdbserver:
2017-09-05 Yao Qi <yao.qi@linaro.org>
* Makefile.in (arch-i386.o): New rule.
* configure.srv (i[34567]86-*-linux*): Add arch-i386.o.
(x86_64-*-linux*): Likewise.
* linux-x86-tdesc.c: Don't include ../features/i386/32bit-XXX.c,
include arch/i386.h.
(i386_linux_read_description): Remove code and call
i386_create_target_description.
* tdesc.c (allocate_target_description): New function.
* tdesc.h (set_tdesc_architecture): Remove declaration.
(set_tdesc_osabi): Likewise.
Diffstat (limited to 'gdb/gdbserver')
-rw-r--r-- | gdb/gdbserver/ChangeLog | 13 | ||||
-rw-r--r-- | gdb/gdbserver/Makefile.in | 8 | ||||
-rw-r--r-- | gdb/gdbserver/configure.srv | 3 | ||||
-rw-r--r-- | gdb/gdbserver/linux-x86-tdesc.c | 39 | ||||
-rw-r--r-- | gdb/gdbserver/tdesc.c | 10 | ||||
-rw-r--r-- | gdb/gdbserver/tdesc.h | 4 |
6 files changed, 37 insertions, 40 deletions
diff --git a/gdb/gdbserver/ChangeLog b/gdb/gdbserver/ChangeLog index 595faf5..2a3d8d2 100644 --- a/gdb/gdbserver/ChangeLog +++ b/gdb/gdbserver/ChangeLog @@ -1,5 +1,18 @@ 2017-09-05 Yao Qi <yao.qi@linaro.org> + * Makefile.in (arch-i386.o): New rule. + * configure.srv (i[34567]86-*-linux*): Add arch-i386.o. + (x86_64-*-linux*): Likewise. + * linux-x86-tdesc.c: Don't include ../features/i386/32bit-XXX.c, + include arch/i386.h. + (i386_linux_read_description): Remove code and call + i386_create_target_description. + * tdesc.c (allocate_target_description): New function. + * tdesc.h (set_tdesc_architecture): Remove declaration. + (set_tdesc_osabi): Likewise. + +2017-09-05 Yao Qi <yao.qi@linaro.org> + * linux-x86-tdesc.c: Don't include <inttypes.h>. (i386_linux_read_description) [!IN_PROCESS_AGENT]: Call set_tdesc_architecture and set_tdesc_osabi. Remove code setting diff --git a/gdb/gdbserver/Makefile.in b/gdb/gdbserver/Makefile.in index 4161152..b552b69 100644 --- a/gdb/gdbserver/Makefile.in +++ b/gdb/gdbserver/Makefile.in @@ -528,6 +528,10 @@ ax.o: ax.c $(COMPILE) $(WARN_CFLAGS_NO_FORMAT) $< $(POSTCOMPILE) +arch-i386.o: ../arch/i386.c + $(COMPILE) $< + $(POSTCOMPILE) + # Rules for objects that go in the in-process agent. %-ipa.o: %-generated.c @@ -553,6 +557,10 @@ ax.o: ax.c $(IPAGENT_COMPILE) $< $(POSTCOMPILE) +%-ipa.o: ../arch/%.c + $(IPAGENT_COMPILE) $< + $(POSTCOMPILE) + # Rules for objects that go in the gdbserver binary. %.o: %-generated.c diff --git a/gdb/gdbserver/configure.srv b/gdb/gdbserver/configure.srv index 1a27012..876098b 100644 --- a/gdb/gdbserver/configure.srv +++ b/gdb/gdbserver/configure.srv @@ -122,6 +122,7 @@ case "${target}" in srv_xmlfiles="${srv_xmlfiles} $srv_amd64_linux_xmlfiles" srv_tgtobj="amd64-linux-siginfo.o" fi + srv_tgtobj="${srv_tgtobj} arch-i386.o" srv_tgtobj="${srv_tgtobj} $srv_linux_obj linux-x86-low.o x86-low.o x86-dregs.o i387-fp.o" srv_tgtobj="${srv_tgtobj} linux-x86-tdesc.o" srv_tgtobj="${srv_tgtobj} linux-btrace.o x86-linux.o" @@ -131,6 +132,7 @@ case "${target}" in srv_linux_thread_db=yes srv_linux_btrace=yes ipa_obj="${ipa_i386_linux_regobj} linux-i386-ipa.o linux-x86-tdesc-ipa.o" + ipa_obj="${ipa_obj} i386-ipa.o" ;; i[34567]86-*-lynxos*) srv_regobj="i386.o" srv_tgtobj="lynx-low.o lynx-i386-low.o fork-child.o fork-inferior.o" @@ -358,6 +360,7 @@ case "${target}" in ;; x86_64-*-linux*) srv_regobj="$srv_amd64_linux_regobj $srv_i386_linux_regobj" srv_tgtobj="$srv_linux_obj linux-x86-low.o x86-low.o x86-dregs.o i387-fp.o" + srv_tgtobj="${srv_tgtobj} arch-i386.o" srv_tgtobj="${srv_tgtobj} linux-x86-tdesc.o" srv_tgtobj="${srv_tgtobj} linux-btrace.o x86-linux.o" srv_tgtobj="${srv_tgtobj} x86-linux-dregs.o" diff --git a/gdb/gdbserver/linux-x86-tdesc.c b/gdb/gdbserver/linux-x86-tdesc.c index 3f63d8e..548e780 100644 --- a/gdb/gdbserver/linux-x86-tdesc.c +++ b/gdb/gdbserver/linux-x86-tdesc.c @@ -20,16 +20,10 @@ #include "server.h" #include "tdesc.h" #include "linux-x86-tdesc.h" -#include "x86-xstate.h" +#include "arch/i386.h" +#include "common/x86-xstate.h" #if defined __i386__ || !defined IN_PROCESS_AGENT -#include "../features/i386/32bit-core.c" -#include "../features/i386/32bit-linux.c" -#include "../features/i386/32bit-sse.c" -#include "../features/i386/32bit-avx.c" -#include "../features/i386/32bit-avx512.c" -#include "../features/i386/32bit-mpx.c" -#include "../features/i386/32bit-pkeys.c" /* Defined in auto-generated file i386-linux.c. */ void init_registers_i386_linux (void); @@ -142,34 +136,7 @@ i386_linux_read_description (uint64_t xcr0) if (*tdesc == NULL) { - *tdesc = new target_desc (); - -#ifndef IN_PROCESS_AGENT - set_tdesc_architecture (*tdesc, "i386"); - set_tdesc_osabi (*tdesc, "GNU/Linux"); -#endif - - long regnum = 0; - - if (xcr0 & X86_XSTATE_X87) - regnum = create_feature_i386_32bit_core (*tdesc, regnum); - - if (xcr0 & X86_XSTATE_SSE) - regnum = create_feature_i386_32bit_sse (*tdesc, regnum); - - regnum = create_feature_i386_32bit_linux (*tdesc, regnum); - - if (xcr0 & X86_XSTATE_AVX) - regnum = create_feature_i386_32bit_avx (*tdesc, regnum); - - if (xcr0 & X86_XSTATE_MPX) - regnum = create_feature_i386_32bit_mpx (*tdesc, regnum); - - if (xcr0 & X86_XSTATE_AVX512) - regnum = create_feature_i386_32bit_avx512 (*tdesc, regnum); - - if (xcr0 & X86_XSTATE_PKRU) - regnum = create_feature_i386_32bit_pkeys (*tdesc, regnum); + *tdesc = i386_create_target_description (xcr0); init_target_desc (*tdesc); diff --git a/gdb/gdbserver/tdesc.c b/gdb/gdbserver/tdesc.c index 0b5096b..53f36d5 100644 --- a/gdb/gdbserver/tdesc.c +++ b/gdb/gdbserver/tdesc.c @@ -39,6 +39,12 @@ init_target_desc (struct target_desc *tdesc) gdb_assert (2 * tdesc->registers_size + 32 <= PBUFSIZ); } +struct target_desc * +allocate_target_description (void) +{ + return new target_desc (); +} + #ifndef IN_PROCESS_AGENT static const struct target_desc default_description {}; @@ -62,6 +68,8 @@ current_target_desc (void) return current_process ()->tdesc; } +/* See arch/tdesc.h. */ + void set_tdesc_architecture (struct target_desc *target_desc, const char *name) @@ -69,6 +77,8 @@ set_tdesc_architecture (struct target_desc *target_desc, target_desc->arch = xstrdup (name); } +/* See arch/tdesc.h. */ + void set_tdesc_osabi (struct target_desc *target_desc, const char *name) { diff --git a/gdb/gdbserver/tdesc.h b/gdb/gdbserver/tdesc.h index fe3c78f..71249e4 100644 --- a/gdb/gdbserver/tdesc.h +++ b/gdb/gdbserver/tdesc.h @@ -142,10 +142,6 @@ void init_target_desc (struct target_desc *tdesc); const struct target_desc *current_target_desc (void); #ifndef IN_PROCESS_AGENT -void set_tdesc_architecture (struct target_desc *target_desc, - const char *name); -void set_tdesc_osabi (struct target_desc *target_desc, const char *name); - const char *tdesc_get_features_xml (struct target_desc *tdesc); #endif |