diff options
Diffstat (limited to 'gdb/features')
111 files changed, 873 insertions, 1186 deletions
diff --git a/gdb/features/Makefile b/gdb/features/Makefile index 3bc8b5a..df24d74 100644 --- a/gdb/features/Makefile +++ b/gdb/features/Makefile @@ -47,21 +47,21 @@ WHICH = aarch64 \ arm/arm-with-iwmmxt arm/arm-with-vfpv2 arm/arm-with-vfpv3 \ arm/arm-with-neon \ i386/i386 i386/i386-linux \ - i386/i386-mmx i386/i386-mmx-linux \ + i386/i386-mmx-linux \ i386/amd64 i386/amd64-linux \ - i386/i386-avx i386/i386-avx-linux \ - i386/i386-mpx i386/i386-mpx-linux \ - i386/i386-avx-mpx i386/i386-avx-mpx-linux \ - i386/i386-avx-avx512 i386/i386-avx-avx512-linux \ - i386/i386-avx-mpx-avx512-pku i386/i386-avx-mpx-avx512-pku-linux \ - i386/amd64-avx i386/amd64-avx-linux \ - i386/amd64-mpx i386/amd64-mpx-linux \ - i386/amd64-avx-mpx i386/amd64-avx-mpx-linux \ - i386/amd64-avx-avx512 i386/amd64-avx-avx512-linux \ - i386/amd64-avx-mpx-avx512-pku i386/amd64-avx-mpx-avx512-pku-linux \ - i386/x32 i386/x32-linux \ - i386/x32-avx i386/x32-avx-linux \ - i386/x32-avx-avx512 i386/x32-avx-avx512-linux \ + i386/i386-avx-linux \ + i386/i386-mpx-linux \ + i386/i386-avx-mpx-linux \ + i386/i386-avx-avx512-linux \ + i386/i386-avx-mpx-avx512-pku-linux \ + i386/amd64-avx-linux \ + i386/amd64-mpx-linux \ + i386/amd64-avx-mpx-linux \ + i386/amd64-avx-avx512-linux \ + i386/amd64-avx-mpx-avx512-pku-linux \ + i386/x32-linux \ + i386/x32-avx-linux \ + i386/x32-avx-avx512-linux \ mips-linux mips-dsp-linux \ microblaze-with-stack-protect \ mips64-linux mips64-dsp-linux \ @@ -165,11 +165,8 @@ XMLTOC = \ i386/i386-avx-mpx.xml \ i386/i386.xml \ i386/x32-avx-linux.xml \ - i386/x32-avx.xml \ i386/x32-avx-avx512-linux.xml \ - i386/x32-avx-avx512.xml \ i386/x32-linux.xml \ - i386/x32.xml \ microblaze-with-stack-protect.xml \ microblaze.xml \ mips-dsp-linux.xml \ @@ -235,7 +232,7 @@ XMLTOC = \ tic6x-c64xp-linux.xml \ tic6x-c64xp.xml -CFILES = $(patsubst %.xml,%.c,$(XMLTOC)) +TDESC_CFILES = $(patsubst %.xml,%.c,$(XMLTOC)) GDB = false all: $(OUTPUTS) @@ -252,10 +249,38 @@ $(outdir)/%.dat: %.xml number-regs.xsl sort-regs.xsl gdbserver-regs.xsl $(XSLTPROC) gdbserver-regs.xsl - >> $(outdir)/$*.tmp sh ../../move-if-change $(outdir)/$*.tmp $(outdir)/$*.dat -cfiles: $(CFILES) -%.c: %.xml +FEATURE_XMLFILES = i386/32bit-core.xml \ + i386/32bit-sse.xml \ + i386/32bit-linux.xml \ + i386/32bit-avx.xml \ + i386/32bit-mpx.xml \ + i386/32bit-avx512.xml \ + i386/32bit-pkeys.xml + +FEATURE_CFILES = $(patsubst %.xml,%.c,$(FEATURE_XMLFILES)) + +cfiles: $(TDESC_CFILES) $(FEATURE_CFILES) + +$(TDESC_CFILES): %.c: %.xml + $(GDB) -nx -q -batch -ex 'maint print c-tdesc $<' > $@.tmp + sh ../../move-if-change $@.tmp $@ + +$(FEATURE_CFILES): %.c: %.xml.tmp $(GDB) -nx -q -batch \ - -ex "set tdesc filename $<" -ex 'maint print c-tdesc' > $@.tmp + -ex 'maint print c-tdesc $<' > $@.tmp + sh ../../move-if-change $@.tmp $@ + rm $< + +# %.xml is the XML file for each target description feature, and +# %.xml.tmp is the XML file target description which only includes +# one target description feature. + +%.xml.tmp: %.xml + echo "<?xml version=\"1.0\"?>" > $@.tmp + echo "<!DOCTYPE target SYSTEM \"gdb-target.dtd\">" >> $@.tmp + echo "<target>" >> $@.tmp + echo " <xi:include href=\"$(notdir $<)\"/>" >> $@.tmp + echo "</target>" >> $@.tmp sh ../../move-if-change $@.tmp $@ # Other dependencies. @@ -263,7 +288,8 @@ $(outdir)/arm/arm-with-iwmmxt.dat: arm/arm-core.xml arm/xscale-iwmmxt.xml $(outdir)/i386/i386.dat: i386/32bit-core.xml i386/32bit-sse.xml $(outdir)/i386/i386-linux.dat: i386/32bit-core.xml i386/32bit-sse.xml \ i386/32bit-linux.xml -$(outdir)/i386/amd64.dat: i386/64bit-core.xml i386/64bit-sse.xml +$(outdir)/i386/amd64.dat: i386/64bit-core.xml i386/64bit-sse.xml \ + i386/64bit-segments.xml $(outdir)/i386/amd64-linux.dat: i386/64bit-core.xml i386/64bit-sse.xml \ i386/64bit-linux.xml i386/64bit-segments.xml $(outdir)/i386/i386-avx.dat: i386/32bit-core.xml i386/32bit-avx.xml @@ -289,7 +315,8 @@ $(outdir)/i386/i386-avx-mpx-avx512-pku-linux.dat: i386/32bit-core.xml \ i386/32bit-pkeys.xml i386/32bit-linux.xml $(outdir)/i386/i386-mmx.dat: i386/32bit-core.xml $(outdir)/i386/i386-mmx-linux.dat: i386/32bit-core.xml i386/32bit-linux.xml -$(outdir)/i386/amd64-avx.dat: i386/64bit-core.xml i386/64bit-avx.xml +$(outdir)/i386/amd64-avx.dat: i386/64bit-core.xml i386/64bit-avx.xml \ + i386/64bit-segments.xml $(outdir)/i386/amd64-avx-linux.dat: i386/64bit-core.xml i386/64bit-avx.xml \ i386/64bit-linux.xml i386/64bit-segments.xml $(outdir)/i386/amd64-mpx-linux.dat: i386/64bit-core.xml i386/64bit-avx.xml \ @@ -297,16 +324,16 @@ $(outdir)/i386/amd64-mpx-linux.dat: i386/64bit-core.xml i386/64bit-avx.xml \ $(outdir)/i386/amd64-avx-mpx-linux.dat: i386/64bit-core.xml \ i386/64bit-linux.xml i386/64bit-segments.xml i386/64bit-mpx.xml $(outdir)/i386/amd64-mpx.dat: i386/64bit-core.xml i386/64bit-avx.xml \ - i386/64bit-mpx.xml + i386/64bit-segments.xml i386/64bit-mpx.xml $(outdir)/i386/amd64-avx-mpx.dat: i386/64bit-core.xml \ - i386/64bit-mpx.xml + i386/64bit-segments.xml i386/64bit-mpx.xml $(outdir)/i386/amd64-avx-avx512.dat: i386/64bit-core.xml i386/64bit-avx.xml \ - i386/64bit-avx512.xml + i386/64bit-avx512.xml i386/64bit-segments.xml $(outdir)/i386/amd64-avx-avx512-linux.dat: i386/64bit-core.xml i386/64bit-avx.xml \ i386/64bit-avx512.xml i386/64bit-linux.xml $(outdir)/i386/amd64-avx-mpx-avx512-pku.dat: i386/64bit-core.xml \ i386/64bit-avx.xml i386/64bit-mpx.xml i386/64bit-avx512.xml \ - i386/64bit-pkeys.xml + i386/64bit-pkeys.xml i386/64bit-segments.xml $(outdir)/i386/amd64-avx-mpx-avx512-pku-linux.dat: i386/64bit-core.xml \ i386/64bit-avx.xml i386/64bit-mpx.xml i386/64bit-avx512.xml \ i386/64bit-linux.xml i386/64bit-segments.xml \ @@ -326,7 +353,7 @@ $(outdir)/i386/x32-avx-avx512-linux.dat: i386/x32-core.xml i386/64bit-avx.xml \ # 'all' doesn't build the C files, so don't delete them in 'clean' # either. clean-cfiles: - rm -f $(CFILES) + rm -f $(TDESC_CFILES) $(FEATURE_CFILES) clean: rm -f $(OUTPUTS) diff --git a/gdb/features/aarch64.c b/gdb/features/aarch64.c index e9eaed8..7411cac 100644 --- a/gdb/features/aarch64.c +++ b/gdb/features/aarch64.c @@ -10,13 +10,13 @@ static void initialize_tdesc_aarch64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("aarch64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.aarch64.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "cpsr_flags", 4); tdesc_add_flag (type, 0, "SP"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/arc-arcompact.c b/gdb/features/arc-arcompact.c index a527cc2..ea84a40 100644 --- a/gdb/features/arc-arcompact.c +++ b/gdb/features/arc-arcompact.c @@ -10,12 +10,10 @@ static void initialize_tdesc_arc_arcompact (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("ARC700")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arc.core.arcompact"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); @@ -53,6 +51,8 @@ initialize_tdesc_arc_arcompact (void) tdesc_create_reg (feature, "pcl", 33, 1, "", 32, "code_ptr"); feature = tdesc_create_feature (result, "org.gnu.gdb.arc.aux-minimal"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "status32_type", 4); tdesc_add_flag (type, 0, "H"); tdesc_add_bitfield (type, "E", 1, 2); diff --git a/gdb/features/arc-v2.c b/gdb/features/arc-v2.c index b2bdfb5..1eefc24 100644 --- a/gdb/features/arc-v2.c +++ b/gdb/features/arc-v2.c @@ -10,12 +10,10 @@ static void initialize_tdesc_arc_v2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("ARCv2")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arc.core.v2"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); @@ -53,6 +51,8 @@ initialize_tdesc_arc_v2 (void) tdesc_create_reg (feature, "pcl", 33, 1, "", 32, "code_ptr"); feature = tdesc_create_feature (result, "org.gnu.gdb.arc.aux-minimal"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "status32_type", 4); tdesc_add_flag (type, 0, "H"); tdesc_add_bitfield (type, "E", 1, 4); diff --git a/gdb/features/arm/arm-with-iwmmxt.c b/gdb/features/arm/arm-with-iwmmxt.c index 1770e03..5f839a0 100644 --- a/gdb/features/arm/arm-with-iwmmxt.c +++ b/gdb/features/arm/arm-with-iwmmxt.c @@ -10,12 +10,10 @@ static void initialize_tdesc_arm_with_iwmmxt (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("iwmmxt")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -36,6 +34,7 @@ initialize_tdesc_arm_with_iwmmxt (void) tdesc_create_reg (feature, "cpsr", 25, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.xscale.iwmmxt"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "uint8"); tdesc_create_vector (feature, "iwmmxt_v8u8", field_type, 8); @@ -45,6 +44,7 @@ initialize_tdesc_arm_with_iwmmxt (void) field_type = tdesc_named_type (feature, "uint32"); tdesc_create_vector (feature, "iwmmxt_v2u32", field_type, 2); + struct tdesc_type *type; type = tdesc_create_union (feature, "iwmmxt_vec64i"); field_type = tdesc_named_type (feature, "iwmmxt_v8u8"); tdesc_add_field (type, "u8", field_type); diff --git a/gdb/features/arm/arm-with-m-fpa-layout.c b/gdb/features/arm/arm-with-m-fpa-layout.c index f720614..99bebc3 100644 --- a/gdb/features/arm/arm-with-m-fpa-layout.c +++ b/gdb/features/arm/arm-with-m-fpa-layout.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_m_fpa_layout (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.m-profile"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/arm/arm-with-m-vfp-d16.c b/gdb/features/arm/arm-with-m-vfp-d16.c index 069baac..ab91673 100644 --- a/gdb/features/arm/arm-with-m-vfp-d16.c +++ b/gdb/features/arm/arm-with-m-vfp-d16.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_m_vfp_d16 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.m-profile"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/arm/arm-with-m.c b/gdb/features/arm/arm-with-m.c index 64d31bb..619fd72 100644 --- a/gdb/features/arm/arm-with-m.c +++ b/gdb/features/arm/arm-with-m.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_m (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.m-profile"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/arm/arm-with-neon.c b/gdb/features/arm/arm-with-neon.c index d365c0f..682ad75 100644 --- a/gdb/features/arm/arm-with-neon.c +++ b/gdb/features/arm/arm-with-neon.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_neon (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/arm/arm-with-vfpv2.c b/gdb/features/arm/arm-with-vfpv2.c index 0ebbfef..368256c 100644 --- a/gdb/features/arm/arm-with-vfpv2.c +++ b/gdb/features/arm/arm-with-vfpv2.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_vfpv2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/arm/arm-with-vfpv3.c b/gdb/features/arm/arm-with-vfpv3.c index e235dfa..ade7c95 100644 --- a/gdb/features/arm/arm-with-vfpv3.c +++ b/gdb/features/arm/arm-with-vfpv3.c @@ -10,10 +10,10 @@ static void initialize_tdesc_arm_with_vfpv3 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("arm")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.arm.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/i386/32bit-avx.c b/gdb/features/i386/32bit-avx.c new file mode 100644 index 0000000..0e71515 --- /dev/null +++ b/gdb/features/i386/32bit-avx.c @@ -0,0 +1,21 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-avx.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_avx (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); + tdesc_create_reg (feature, "ymm0h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm1h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm2h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm3h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm4h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm5h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm6h", regnum++, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm7h", regnum++, 1, NULL, 128, "uint128"); + return regnum; +} diff --git a/gdb/features/i386/32bit-avx512.c b/gdb/features/i386/32bit-avx512.c new file mode 100644 index 0000000..034f557 --- /dev/null +++ b/gdb/features/i386/32bit-avx512.c @@ -0,0 +1,33 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-avx512.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_avx512 (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx512"); + struct tdesc_type *field_type; + field_type = tdesc_named_type (feature, "uint128"); + tdesc_create_vector (feature, "v2ui128", field_type, 2); + + tdesc_create_reg (feature, "k0", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k1", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k2", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k3", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k4", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k5", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k6", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k7", regnum++, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "zmm0h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm1h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm2h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm3h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm4h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm5h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm6h", regnum++, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm7h", regnum++, 1, NULL, 256, "v2ui128"); + return regnum; +} diff --git a/gdb/features/i386/32bit-core.c b/gdb/features/i386/32bit-core.c new file mode 100644 index 0000000..b43de4d --- /dev/null +++ b/gdb/features/i386/32bit-core.c @@ -0,0 +1,66 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-core.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_core (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; + type = tdesc_create_flags (feature, "i386_eflags", 4); + tdesc_add_flag (type, 0, "CF"); + tdesc_add_flag (type, 1, ""); + tdesc_add_flag (type, 2, "PF"); + tdesc_add_flag (type, 4, "AF"); + tdesc_add_flag (type, 6, "ZF"); + tdesc_add_flag (type, 7, "SF"); + tdesc_add_flag (type, 8, "TF"); + tdesc_add_flag (type, 9, "IF"); + tdesc_add_flag (type, 10, "DF"); + tdesc_add_flag (type, 11, "OF"); + tdesc_add_flag (type, 14, "NT"); + tdesc_add_flag (type, 16, "RF"); + tdesc_add_flag (type, 17, "VM"); + tdesc_add_flag (type, 18, "AC"); + tdesc_add_flag (type, 19, "VIF"); + tdesc_add_flag (type, 20, "VIP"); + tdesc_add_flag (type, 21, "ID"); + + tdesc_create_reg (feature, "eax", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "ecx", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "edx", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "ebx", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "esp", regnum++, 1, NULL, 32, "data_ptr"); + tdesc_create_reg (feature, "ebp", regnum++, 1, NULL, 32, "data_ptr"); + tdesc_create_reg (feature, "esi", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "edi", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "eip", regnum++, 1, NULL, 32, "code_ptr"); + tdesc_create_reg (feature, "eflags", regnum++, 1, NULL, 32, "i386_eflags"); + tdesc_create_reg (feature, "cs", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "ss", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "ds", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "es", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "fs", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "gs", regnum++, 1, NULL, 32, "int32"); + tdesc_create_reg (feature, "st0", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st1", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st2", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st3", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st4", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st5", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st6", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "st7", regnum++, 1, NULL, 80, "i387_ext"); + tdesc_create_reg (feature, "fctrl", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "fstat", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "ftag", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "fiseg", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "fioff", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "foseg", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "fooff", regnum++, 1, "float", 32, "int"); + tdesc_create_reg (feature, "fop", regnum++, 1, "float", 32, "int"); + return regnum; +} diff --git a/gdb/features/i386/32bit-linux.c b/gdb/features/i386/32bit-linux.c new file mode 100644 index 0000000..1b50882 --- /dev/null +++ b/gdb/features/i386/32bit-linux.c @@ -0,0 +1,15 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-linux.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_linux (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.linux"); + regnum = 41; + tdesc_create_reg (feature, "orig_eax", regnum++, 1, NULL, 32, "int"); + return regnum; +} diff --git a/gdb/features/i386/32bit-mpx.c b/gdb/features/i386/32bit-mpx.c new file mode 100644 index 0000000..6ed3b2e --- /dev/null +++ b/gdb/features/i386/32bit-mpx.c @@ -0,0 +1,51 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-mpx.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_mpx (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.mpx"); + struct tdesc_type *field_type; + struct tdesc_type *type; + type = tdesc_create_struct (feature, "br128"); + field_type = tdesc_named_type (feature, "uint64"); + tdesc_add_field (type, "lbound", field_type); + field_type = tdesc_named_type (feature, "uint64"); + tdesc_add_field (type, "ubound_raw", field_type); + + type = tdesc_create_struct (feature, "_bndstatus"); + tdesc_set_struct_size (type, 8); + tdesc_add_bitfield (type, "bde", 2, 31); + tdesc_add_bitfield (type, "error", 0, 1); + + type = tdesc_create_union (feature, "status"); + field_type = tdesc_named_type (feature, "data_ptr"); + tdesc_add_field (type, "raw", field_type); + field_type = tdesc_named_type (feature, "_bndstatus"); + tdesc_add_field (type, "status", field_type); + + type = tdesc_create_struct (feature, "_bndcfgu"); + tdesc_set_struct_size (type, 8); + tdesc_add_bitfield (type, "base", 12, 31); + tdesc_add_bitfield (type, "reserved", 2, 11); + tdesc_add_bitfield (type, "preserved", 1, 1); + tdesc_add_bitfield (type, "enabled", 0, 0); + + type = tdesc_create_union (feature, "cfgu"); + field_type = tdesc_named_type (feature, "data_ptr"); + tdesc_add_field (type, "raw", field_type); + field_type = tdesc_named_type (feature, "_bndcfgu"); + tdesc_add_field (type, "config", field_type); + + tdesc_create_reg (feature, "bnd0raw", regnum++, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd1raw", regnum++, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd2raw", regnum++, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd3raw", regnum++, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bndcfgu", regnum++, 1, NULL, 64, "cfgu"); + tdesc_create_reg (feature, "bndstatus", regnum++, 1, NULL, 64, "status"); + return regnum; +} diff --git a/gdb/features/i386/32bit-pkeys.c b/gdb/features/i386/32bit-pkeys.c new file mode 100644 index 0000000..24a40aa3 --- /dev/null +++ b/gdb/features/i386/32bit-pkeys.c @@ -0,0 +1,14 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-pkeys.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_pkeys (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.pkeys"); + tdesc_create_reg (feature, "pkru", regnum++, 1, NULL, 32, "uint32"); + return regnum; +} diff --git a/gdb/features/i386/32bit-sse.c b/gdb/features/i386/32bit-sse.c new file mode 100644 index 0000000..c0684fb --- /dev/null +++ b/gdb/features/i386/32bit-sse.c @@ -0,0 +1,75 @@ +/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: + Original: 32bit-sse.xml */ + +#include "target-descriptions.h" + +static int +create_feature_i386_32bit_sse (struct target_desc *result, long regnum) +{ + struct tdesc_feature *feature; + + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.sse"); + struct tdesc_type *field_type; + field_type = tdesc_named_type (feature, "ieee_single"); + tdesc_create_vector (feature, "v4f", field_type, 4); + + field_type = tdesc_named_type (feature, "ieee_double"); + tdesc_create_vector (feature, "v2d", field_type, 2); + + field_type = tdesc_named_type (feature, "int8"); + tdesc_create_vector (feature, "v16i8", field_type, 16); + + field_type = tdesc_named_type (feature, "int16"); + tdesc_create_vector (feature, "v8i16", field_type, 8); + + field_type = tdesc_named_type (feature, "int32"); + tdesc_create_vector (feature, "v4i32", field_type, 4); + + field_type = tdesc_named_type (feature, "int64"); + tdesc_create_vector (feature, "v2i64", field_type, 2); + + struct tdesc_type *type; + type = tdesc_create_union (feature, "vec128"); + field_type = tdesc_named_type (feature, "v4f"); + tdesc_add_field (type, "v4_float", field_type); + field_type = tdesc_named_type (feature, "v2d"); + tdesc_add_field (type, "v2_double", field_type); + field_type = tdesc_named_type (feature, "v16i8"); + tdesc_add_field (type, "v16_int8", field_type); + field_type = tdesc_named_type (feature, "v8i16"); + tdesc_add_field (type, "v8_int16", field_type); + field_type = tdesc_named_type (feature, "v4i32"); + tdesc_add_field (type, "v4_int32", field_type); + field_type = tdesc_named_type (feature, "v2i64"); + tdesc_add_field (type, "v2_int64", field_type); + field_type = tdesc_named_type (feature, "uint128"); + tdesc_add_field (type, "uint128", field_type); + + type = tdesc_create_flags (feature, "i386_mxcsr", 4); + tdesc_add_flag (type, 0, "IE"); + tdesc_add_flag (type, 1, "DE"); + tdesc_add_flag (type, 2, "ZE"); + tdesc_add_flag (type, 3, "OE"); + tdesc_add_flag (type, 4, "UE"); + tdesc_add_flag (type, 5, "PE"); + tdesc_add_flag (type, 6, "DAZ"); + tdesc_add_flag (type, 7, "IM"); + tdesc_add_flag (type, 8, "DM"); + tdesc_add_flag (type, 9, "ZM"); + tdesc_add_flag (type, 10, "OM"); + tdesc_add_flag (type, 11, "UM"); + tdesc_add_flag (type, 12, "PM"); + tdesc_add_flag (type, 15, "FZ"); + + regnum = 32; + tdesc_create_reg (feature, "xmm0", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm1", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm2", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm3", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm4", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm5", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm6", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm7", regnum++, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "mxcsr", regnum++, 1, "vector", 32, "i386_mxcsr"); + return regnum; +} diff --git a/gdb/features/i386/amd64-avx-avx512-linux.c b/gdb/features/i386/amd64-avx-avx512-linux.c index 6129ab1..de58f06 100644 --- a/gdb/features/i386/amd64-avx-avx512-linux.c +++ b/gdb/features/i386/amd64-avx-avx512-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_avx_avx512_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -282,7 +282,7 @@ initialize_tdesc_amd64_avx_avx512_linux (void) tdesc_create_reg (feature, "zmm28h", 144, 1, NULL, 256, "v2ui128"); tdesc_create_reg (feature, "zmm29h", 145, 1, NULL, 256, "v2ui128"); tdesc_create_reg (feature, "zmm30h", 146, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm31h", 146, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm31h", 147, 1, NULL, 256, "v2ui128"); tdesc_amd64_avx_avx512_linux = result; } diff --git a/gdb/features/i386/amd64-avx-avx512.c b/gdb/features/i386/amd64-avx-avx512.c index 8a185c1..354d826 100644 --- a/gdb/features/i386/amd64-avx-avx512.c +++ b/gdb/features/i386/amd64-avx-avx512.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64_avx_avx512 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,23 +146,27 @@ initialize_tdesc_amd64_avx_avx512 (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm0h", 59, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm1h", 60, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm2h", 61, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm3h", 62, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm4h", 63, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm5h", 64, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm6h", 65, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm7h", 66, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm8h", 67, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm9h", 68, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm10h", 69, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm11h", 70, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm12h", 71, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm13h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm14h", 73, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm15h", 74, 1, NULL, 128, "uint128"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx512"); field_type = tdesc_named_type (feature, "ieee_single"); @@ -202,78 +206,78 @@ initialize_tdesc_amd64_avx_avx512 (void) field_type = tdesc_named_type (feature, "uint128"); tdesc_create_vector (feature, "v2ui128", field_type, 2); - tdesc_create_reg (feature, "xmm16", 73, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm17", 74, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm18", 75, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm19", 76, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm20", 77, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm21", 78, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm22", 79, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm23", 80, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm24", 81, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm25", 82, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm26", 83, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm27", 84, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm28", 85, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm29", 86, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm30", 87, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm31", 88, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "ymm16h", 89, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm17h", 90, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm18h", 91, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm19h", 92, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm20h", 93, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm21h", 94, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm22h", 95, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm23h", 96, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm24h", 97, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm25h", 98, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm26h", 99, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm27h", 100, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm28h", 101, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm29h", 102, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm30h", 103, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm31h", 104, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "k0", 105, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k1", 106, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k2", 107, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k3", 108, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k4", 109, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k5", 110, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k6", 111, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k7", 112, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "zmm0h", 113, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm1h", 114, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm2h", 115, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm3h", 116, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm4h", 117, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm5h", 118, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm6h", 119, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm7h", 120, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm8h", 121, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm9h", 122, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm10h", 123, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm11h", 124, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm12h", 125, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm13h", 126, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm14h", 127, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm15h", 128, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm16h", 129, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm17h", 130, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm18h", 131, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm19h", 132, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm20h", 133, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm21h", 134, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm22h", 135, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm23h", 136, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm24h", 137, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm25h", 138, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm26h", 139, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm27h", 140, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm28h", 141, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm29h", 142, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm30h", 143, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm31h", 144, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "xmm16", 75, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm17", 76, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm18", 77, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm19", 78, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm20", 79, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm21", 80, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm22", 81, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm23", 82, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm24", 83, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm25", 84, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm26", 85, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm27", 86, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm28", 87, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm29", 88, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm30", 89, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm31", 90, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "ymm16h", 91, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm17h", 92, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm18h", 93, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm19h", 94, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm20h", 95, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm21h", 96, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm22h", 97, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm23h", 98, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm24h", 99, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm25h", 100, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm26h", 101, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm27h", 102, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm28h", 103, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm29h", 104, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm30h", 105, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm31h", 106, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "k0", 107, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k1", 108, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k2", 109, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k3", 110, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k4", 111, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k5", 112, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k6", 113, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k7", 114, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "zmm0h", 115, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm1h", 116, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm2h", 117, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm3h", 118, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm4h", 119, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm5h", 120, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm6h", 121, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm7h", 122, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm8h", 123, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm9h", 124, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm10h", 125, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm11h", 126, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm12h", 127, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm13h", 128, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm14h", 129, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm15h", 130, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm16h", 131, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm17h", 132, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm18h", 133, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm19h", 134, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm20h", 135, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm21h", 136, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm22h", 137, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm23h", 138, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm24h", 139, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm25h", 140, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm26h", 141, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm27h", 142, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm28h", 143, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm29h", 144, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm30h", 145, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm31h", 146, 1, NULL, 256, "v2ui128"); tdesc_amd64_avx_avx512 = result; } diff --git a/gdb/features/i386/amd64-avx-avx512.xml b/gdb/features/i386/amd64-avx-avx512.xml index a458743..fdf8136 100644 --- a/gdb/features/i386/amd64-avx-avx512.xml +++ b/gdb/features/i386/amd64-avx-avx512.xml @@ -12,6 +12,7 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> <xi:include href="64bit-avx.xml"/> <xi:include href="64bit-avx512.xml"/> </target> diff --git a/gdb/features/i386/amd64-avx-linux.c b/gdb/features/i386/amd64-avx-linux.c index 1d56dbf..00dfd3c 100644 --- a/gdb/features/i386/amd64-avx-linux.c +++ b/gdb/features/i386/amd64-avx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_avx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/amd64-avx-mpx-avx512-pku-linux.c b/gdb/features/i386/amd64-avx-mpx-avx512-pku-linux.c index 248eff7..7fd016f 100644 --- a/gdb/features/i386/amd64-avx-mpx-avx512-pku-linux.c +++ b/gdb/features/i386/amd64-avx-mpx-avx512-pku-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_avx_mpx_avx512_pku_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -323,7 +323,7 @@ initialize_tdesc_amd64_avx_mpx_avx512_pku_linux (void) tdesc_create_reg (feature, "zmm31h", 153, 1, NULL, 256, "v2ui128"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.pkeys"); - tdesc_create_reg (feature, "pkru", 152, 1, NULL, 32, "uint32"); + tdesc_create_reg (feature, "pkru", 154, 1, NULL, 32, "uint32"); tdesc_amd64_avx_mpx_avx512_pku_linux = result; } diff --git a/gdb/features/i386/amd64-avx-mpx-avx512-pku.c b/gdb/features/i386/amd64-avx-mpx-avx512-pku.c index dfe7d77..bade64d 100644 --- a/gdb/features/i386/amd64-avx-mpx-avx512-pku.c +++ b/gdb/features/i386/amd64-avx-mpx-avx512-pku.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64_avx_mpx_avx512_pku (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,23 +146,27 @@ initialize_tdesc_amd64_avx_mpx_avx512_pku (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm0h", 59, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm1h", 60, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm2h", 61, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm3h", 62, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm4h", 63, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm5h", 64, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm6h", 65, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm7h", 66, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm8h", 67, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm9h", 68, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm10h", 69, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm11h", 70, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm12h", 71, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm13h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm14h", 73, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm15h", 74, 1, NULL, 128, "uint128"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.mpx"); type = tdesc_create_struct (feature, "br128"); @@ -195,12 +199,12 @@ initialize_tdesc_amd64_avx_mpx_avx512_pku (void) field_type = tdesc_named_type (feature, "_bndcfgu"); tdesc_add_field (type, "config", field_type); - tdesc_create_reg (feature, "bnd0raw", 73, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd1raw", 74, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd2raw", 75, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd3raw", 76, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bndcfgu", 77, 1, NULL, 64, "cfgu"); - tdesc_create_reg (feature, "bndstatus", 78, 1, NULL, 64, "status"); + tdesc_create_reg (feature, "bnd0raw", 75, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd1raw", 76, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd2raw", 77, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd3raw", 78, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bndcfgu", 79, 1, NULL, 64, "cfgu"); + tdesc_create_reg (feature, "bndstatus", 80, 1, NULL, 64, "status"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx512"); field_type = tdesc_named_type (feature, "ieee_single"); @@ -240,81 +244,81 @@ initialize_tdesc_amd64_avx_mpx_avx512_pku (void) field_type = tdesc_named_type (feature, "uint128"); tdesc_create_vector (feature, "v2ui128", field_type, 2); - tdesc_create_reg (feature, "xmm16", 79, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm17", 80, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm18", 81, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm19", 82, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm20", 83, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm21", 84, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm22", 85, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm23", 86, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm24", 87, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm25", 88, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm26", 89, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm27", 90, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm28", 91, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm29", 92, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm30", 93, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm31", 94, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "ymm16h", 95, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm17h", 96, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm18h", 97, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm19h", 98, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm20h", 99, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm21h", 100, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm22h", 101, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm23h", 102, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm24h", 103, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm25h", 104, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm26h", 105, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm27h", 106, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm28h", 107, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm29h", 108, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm30h", 109, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm31h", 110, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "k0", 111, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k1", 112, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k2", 113, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k3", 114, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k4", 115, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k5", 116, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k6", 117, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k7", 118, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "zmm0h", 119, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm1h", 120, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm2h", 121, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm3h", 122, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm4h", 123, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm5h", 124, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm6h", 125, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm7h", 126, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm8h", 127, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm9h", 128, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm10h", 129, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm11h", 130, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm12h", 131, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm13h", 132, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm14h", 133, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm15h", 134, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm16h", 135, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm17h", 136, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm18h", 137, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm19h", 138, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm20h", 139, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm21h", 140, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm22h", 141, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm23h", 142, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm24h", 143, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm25h", 144, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm26h", 145, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm27h", 146, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm28h", 147, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm29h", 148, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm30h", 149, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm31h", 150, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "xmm16", 81, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm17", 82, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm18", 83, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm19", 84, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm20", 85, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm21", 86, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm22", 87, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm23", 88, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm24", 89, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm25", 90, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm26", 91, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm27", 92, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm28", 93, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm29", 94, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm30", 95, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "xmm31", 96, 1, NULL, 128, "vec128"); + tdesc_create_reg (feature, "ymm16h", 97, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm17h", 98, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm18h", 99, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm19h", 100, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm20h", 101, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm21h", 102, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm22h", 103, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm23h", 104, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm24h", 105, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm25h", 106, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm26h", 107, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm27h", 108, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm28h", 109, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm29h", 110, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm30h", 111, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm31h", 112, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "k0", 113, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k1", 114, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k2", 115, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k3", 116, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k4", 117, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k5", 118, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k6", 119, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "k7", 120, 1, NULL, 64, "uint64"); + tdesc_create_reg (feature, "zmm0h", 121, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm1h", 122, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm2h", 123, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm3h", 124, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm4h", 125, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm5h", 126, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm6h", 127, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm7h", 128, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm8h", 129, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm9h", 130, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm10h", 131, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm11h", 132, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm12h", 133, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm13h", 134, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm14h", 135, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm15h", 136, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm16h", 137, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm17h", 138, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm18h", 139, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm19h", 140, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm20h", 141, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm21h", 142, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm22h", 143, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm23h", 144, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm24h", 145, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm25h", 146, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm26h", 147, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm27h", 148, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm28h", 149, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm29h", 150, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm30h", 151, 1, NULL, 256, "v2ui128"); + tdesc_create_reg (feature, "zmm31h", 152, 1, NULL, 256, "v2ui128"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.pkeys"); - tdesc_create_reg (feature, "pkru", 151, 1, NULL, 32, "uint32"); + tdesc_create_reg (feature, "pkru", 153, 1, NULL, 32, "uint32"); tdesc_amd64_avx_mpx_avx512_pku = result; } diff --git a/gdb/features/i386/amd64-avx-mpx-avx512-pku.xml b/gdb/features/i386/amd64-avx-mpx-avx512-pku.xml index e769108..d8203e3 100644 --- a/gdb/features/i386/amd64-avx-mpx-avx512-pku.xml +++ b/gdb/features/i386/amd64-avx-mpx-avx512-pku.xml @@ -12,6 +12,7 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> <xi:include href="64bit-avx.xml"/> <xi:include href="64bit-mpx.xml"/> <xi:include href="64bit-avx512.xml"/> diff --git a/gdb/features/i386/amd64-avx-mpx-linux.c b/gdb/features/i386/amd64-avx-mpx-linux.c index 26c1339..5fe1127 100644 --- a/gdb/features/i386/amd64-avx-mpx-linux.c +++ b/gdb/features/i386/amd64-avx-mpx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_avx_mpx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/amd64-avx-mpx.c b/gdb/features/i386/amd64-avx-mpx.c index ab56f42..5dced15 100644 --- a/gdb/features/i386/amd64-avx-mpx.c +++ b/gdb/features/i386/amd64-avx-mpx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64_avx_mpx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,23 +146,27 @@ initialize_tdesc_amd64_avx_mpx (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm0h", 59, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm1h", 60, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm2h", 61, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm3h", 62, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm4h", 63, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm5h", 64, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm6h", 65, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm7h", 66, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm8h", 67, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm9h", 68, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm10h", 69, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm11h", 70, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm12h", 71, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm13h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm14h", 73, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm15h", 74, 1, NULL, 128, "uint128"); feature = tdesc_create_feature (result, "org.gnu.gdb.i386.mpx"); type = tdesc_create_struct (feature, "br128"); @@ -195,12 +199,12 @@ initialize_tdesc_amd64_avx_mpx (void) field_type = tdesc_named_type (feature, "_bndcfgu"); tdesc_add_field (type, "config", field_type); - tdesc_create_reg (feature, "bnd0raw", 73, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd1raw", 74, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd2raw", 75, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd3raw", 76, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bndcfgu", 77, 1, NULL, 64, "cfgu"); - tdesc_create_reg (feature, "bndstatus", 78, 1, NULL, 64, "status"); + tdesc_create_reg (feature, "bnd0raw", 75, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd1raw", 76, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd2raw", 77, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd3raw", 78, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bndcfgu", 79, 1, NULL, 64, "cfgu"); + tdesc_create_reg (feature, "bndstatus", 80, 1, NULL, 64, "status"); tdesc_amd64_avx_mpx = result; } diff --git a/gdb/features/i386/amd64-avx-mpx.xml b/gdb/features/i386/amd64-avx-mpx.xml index 0001dc8..001cc58 100644 --- a/gdb/features/i386/amd64-avx-mpx.xml +++ b/gdb/features/i386/amd64-avx-mpx.xml @@ -12,6 +12,7 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> <xi:include href="64bit-avx.xml"/> <xi:include href="64bit-mpx.xml"/> </target> diff --git a/gdb/features/i386/amd64-avx.c b/gdb/features/i386/amd64-avx.c index 42bd69a..016689a 100644 --- a/gdb/features/i386/amd64-avx.c +++ b/gdb/features/i386/amd64-avx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64_avx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,23 +146,27 @@ initialize_tdesc_amd64_avx (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm0h", 59, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm1h", 60, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm2h", 61, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm3h", 62, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm4h", 63, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm5h", 64, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm6h", 65, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm7h", 66, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm8h", 67, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm9h", 68, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm10h", 69, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm11h", 70, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm12h", 71, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm13h", 72, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm14h", 73, 1, NULL, 128, "uint128"); + tdesc_create_reg (feature, "ymm15h", 74, 1, NULL, 128, "uint128"); tdesc_amd64_avx = result; } diff --git a/gdb/features/i386/amd64-avx.xml b/gdb/features/i386/amd64-avx.xml index d3b63b8..a0fec55 100644 --- a/gdb/features/i386/amd64-avx.xml +++ b/gdb/features/i386/amd64-avx.xml @@ -12,5 +12,6 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> <xi:include href="64bit-avx.xml"/> </target> diff --git a/gdb/features/i386/amd64-linux.c b/gdb/features/i386/amd64-linux.c index 0e921ba9..58c4405 100644 --- a/gdb/features/i386/amd64-linux.c +++ b/gdb/features/i386/amd64-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/amd64-mpx-linux.c b/gdb/features/i386/amd64-mpx-linux.c index e26a74a..dcf92f9 100644 --- a/gdb/features/i386/amd64-mpx-linux.c +++ b/gdb/features/i386/amd64-mpx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_amd64_mpx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/amd64-mpx.c b/gdb/features/i386/amd64-mpx.c index 41f0e78..ed7767d 100644 --- a/gdb/features/i386/amd64-mpx.c +++ b/gdb/features/i386/amd64-mpx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64_mpx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,6 +146,10 @@ initialize_tdesc_amd64_mpx (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.mpx"); type = tdesc_create_struct (feature, "br128"); field_type = tdesc_named_type (feature, "uint64"); @@ -177,12 +181,12 @@ initialize_tdesc_amd64_mpx (void) field_type = tdesc_named_type (feature, "_bndcfgu"); tdesc_add_field (type, "config", field_type); - tdesc_create_reg (feature, "bnd0raw", 57, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd1raw", 58, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd2raw", 59, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bnd3raw", 60, 1, NULL, 128, "br128"); - tdesc_create_reg (feature, "bndcfgu", 61, 1, NULL, 64, "cfgu"); - tdesc_create_reg (feature, "bndstatus", 62, 1, NULL, 64, "status"); + tdesc_create_reg (feature, "bnd0raw", 59, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd1raw", 60, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd2raw", 61, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bnd3raw", 62, 1, NULL, 128, "br128"); + tdesc_create_reg (feature, "bndcfgu", 63, 1, NULL, 64, "cfgu"); + tdesc_create_reg (feature, "bndstatus", 64, 1, NULL, 64, "status"); tdesc_amd64_mpx = result; } diff --git a/gdb/features/i386/amd64-mpx.xml b/gdb/features/i386/amd64-mpx.xml index 7692006..7e0253d 100644 --- a/gdb/features/i386/amd64-mpx.xml +++ b/gdb/features/i386/amd64-mpx.xml @@ -12,5 +12,6 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> <xi:include href="64bit-mpx.xml"/> </target> diff --git a/gdb/features/i386/amd64.c b/gdb/features/i386/amd64.c index b875a9b..4ad79cb 100644 --- a/gdb/features/i386/amd64.c +++ b/gdb/features/i386/amd64.c @@ -10,13 +10,13 @@ static void initialize_tdesc_amd64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x86-64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); @@ -146,5 +146,9 @@ initialize_tdesc_amd64 (void) tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.segments"); + tdesc_create_reg (feature, "fs_base", 57, 1, NULL, 64, "int"); + tdesc_create_reg (feature, "gs_base", 58, 1, NULL, 64, "int"); + tdesc_amd64 = result; } diff --git a/gdb/features/i386/amd64.xml b/gdb/features/i386/amd64.xml index d11c07e..1962a2a 100644 --- a/gdb/features/i386/amd64.xml +++ b/gdb/features/i386/amd64.xml @@ -12,4 +12,5 @@ <architecture>i386:x86-64</architecture> <xi:include href="64bit-core.xml"/> <xi:include href="64bit-sse.xml"/> + <xi:include href="64bit-segments.xml"/> </target> diff --git a/gdb/features/i386/i386-avx-avx512-linux.c b/gdb/features/i386/i386-avx-avx512-linux.c index 81149d5..545149d 100644 --- a/gdb/features/i386/i386-avx-avx512-linux.c +++ b/gdb/features/i386/i386-avx-avx512-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_avx_avx512_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-avx512.c b/gdb/features/i386/i386-avx-avx512.c index 1075ca0..585a0ac 100644 --- a/gdb/features/i386/i386-avx-avx512.c +++ b/gdb/features/i386/i386-avx-avx512.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_avx_avx512 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-linux.c b/gdb/features/i386/i386-avx-linux.c index 4a8c6b5..3ef087d 100644 --- a/gdb/features/i386/i386-avx-linux.c +++ b/gdb/features/i386/i386-avx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_avx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-mpx-avx512-pku-linux.c b/gdb/features/i386/i386-avx-mpx-avx512-pku-linux.c index f90c834..e6eebf1 100644 --- a/gdb/features/i386/i386-avx-mpx-avx512-pku-linux.c +++ b/gdb/features/i386/i386-avx-mpx-avx512-pku-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_avx_mpx_avx512_pku_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-mpx-avx512-pku.c b/gdb/features/i386/i386-avx-mpx-avx512-pku.c index 08d9b4b..d7dd3bb 100644 --- a/gdb/features/i386/i386-avx-mpx-avx512-pku.c +++ b/gdb/features/i386/i386-avx-mpx-avx512-pku.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_avx_mpx_avx512_pku (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-mpx-linux.c b/gdb/features/i386/i386-avx-mpx-linux.c index 4b27bfc..f62c487 100644 --- a/gdb/features/i386/i386-avx-mpx-linux.c +++ b/gdb/features/i386/i386-avx-mpx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_avx_mpx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx-mpx.c b/gdb/features/i386/i386-avx-mpx.c index b27b40a..f479bda 100644 --- a/gdb/features/i386/i386-avx-mpx.c +++ b/gdb/features/i386/i386-avx-mpx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_avx_mpx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-avx.c b/gdb/features/i386/i386-avx.c index 1cb0f9e..f888335 100644 --- a/gdb/features/i386/i386-avx.c +++ b/gdb/features/i386/i386-avx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_avx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-linux.c b/gdb/features/i386/i386-linux.c index c7796c3..0394842 100644 --- a/gdb/features/i386/i386-linux.c +++ b/gdb/features/i386/i386-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-mmx-linux.c b/gdb/features/i386/i386-mmx-linux.c index e53b55f..1577972 100644 --- a/gdb/features/i386/i386-mmx-linux.c +++ b/gdb/features/i386/i386-mmx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_mmx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-mmx.c b/gdb/features/i386/i386-mmx.c index 74f67ed..02aee89 100644 --- a/gdb/features/i386/i386-mmx.c +++ b/gdb/features/i386/i386-mmx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_mmx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-mpx-linux.c b/gdb/features/i386/i386-mpx-linux.c index 43ea192..6dea8e0 100644 --- a/gdb/features/i386/i386-mpx-linux.c +++ b/gdb/features/i386/i386-mpx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_i386_mpx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386-mpx.c b/gdb/features/i386/i386-mpx.c index e832d2e..d08441b 100644 --- a/gdb/features/i386/i386-mpx.c +++ b/gdb/features/i386/i386-mpx.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386_mpx (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/i386.c b/gdb/features/i386/i386.c index ede73fc..eb9a266 100644 --- a/gdb/features/i386/i386.c +++ b/gdb/features/i386/i386.c @@ -10,13 +10,13 @@ static void initialize_tdesc_i386 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/x32-avx-avx512-linux.c b/gdb/features/i386/x32-avx-avx512-linux.c index 0467d87..c023a10 100644 --- a/gdb/features/i386/x32-avx-avx512-linux.c +++ b/gdb/features/i386/x32-avx-avx512-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_x32_avx_avx512_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/x32-avx-avx512.c b/gdb/features/i386/x32-avx-avx512.c deleted file mode 100644 index a7a2d52..0000000 --- a/gdb/features/i386/x32-avx-avx512.c +++ /dev/null @@ -1,279 +0,0 @@ -/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: - Original: x32-avx-avx512.xml */ - -#include "defs.h" -#include "osabi.h" -#include "target-descriptions.h" - -struct target_desc *tdesc_x32_avx_avx512; -static void -initialize_tdesc_x32_avx_avx512 (void) -{ - struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); - type = tdesc_create_flags (feature, "i386_eflags", 4); - tdesc_add_flag (type, 0, "CF"); - tdesc_add_flag (type, 1, ""); - tdesc_add_flag (type, 2, "PF"); - tdesc_add_flag (type, 4, "AF"); - tdesc_add_flag (type, 6, "ZF"); - tdesc_add_flag (type, 7, "SF"); - tdesc_add_flag (type, 8, "TF"); - tdesc_add_flag (type, 9, "IF"); - tdesc_add_flag (type, 10, "DF"); - tdesc_add_flag (type, 11, "OF"); - tdesc_add_flag (type, 14, "NT"); - tdesc_add_flag (type, 16, "RF"); - tdesc_add_flag (type, 17, "VM"); - tdesc_add_flag (type, 18, "AC"); - tdesc_add_flag (type, 19, "VIF"); - tdesc_add_flag (type, 20, "VIP"); - tdesc_add_flag (type, 21, "ID"); - - tdesc_create_reg (feature, "rax", 0, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbx", 1, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rcx", 2, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdx", 3, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsi", 4, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdi", 5, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbp", 6, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsp", 7, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r8", 8, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r9", 9, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r10", 10, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r11", 11, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r12", 12, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r13", 13, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r14", 14, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r15", 15, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rip", 16, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "eflags", 17, 1, NULL, 32, "i386_eflags"); - tdesc_create_reg (feature, "cs", 18, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ss", 19, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ds", 20, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "es", 21, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "fs", 22, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "gs", 23, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "st0", 24, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st1", 25, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st2", 26, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st3", 27, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st4", 28, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st5", 29, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st6", 30, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st7", 31, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "fctrl", 32, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fstat", 33, 1, "float", 32, "int"); - tdesc_create_reg (feature, "ftag", 34, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fiseg", 35, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fioff", 36, 1, "float", 32, "int"); - tdesc_create_reg (feature, "foseg", 37, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fooff", 38, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fop", 39, 1, "float", 32, "int"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.sse"); - field_type = tdesc_named_type (feature, "ieee_single"); - tdesc_create_vector (feature, "v4f", field_type, 4); - - field_type = tdesc_named_type (feature, "ieee_double"); - tdesc_create_vector (feature, "v2d", field_type, 2); - - field_type = tdesc_named_type (feature, "int8"); - tdesc_create_vector (feature, "v16i8", field_type, 16); - - field_type = tdesc_named_type (feature, "int16"); - tdesc_create_vector (feature, "v8i16", field_type, 8); - - field_type = tdesc_named_type (feature, "int32"); - tdesc_create_vector (feature, "v4i32", field_type, 4); - - field_type = tdesc_named_type (feature, "int64"); - tdesc_create_vector (feature, "v2i64", field_type, 2); - - type = tdesc_create_union (feature, "vec128"); - field_type = tdesc_named_type (feature, "v4f"); - tdesc_add_field (type, "v4_float", field_type); - field_type = tdesc_named_type (feature, "v2d"); - tdesc_add_field (type, "v2_double", field_type); - field_type = tdesc_named_type (feature, "v16i8"); - tdesc_add_field (type, "v16_int8", field_type); - field_type = tdesc_named_type (feature, "v8i16"); - tdesc_add_field (type, "v8_int16", field_type); - field_type = tdesc_named_type (feature, "v4i32"); - tdesc_add_field (type, "v4_int32", field_type); - field_type = tdesc_named_type (feature, "v2i64"); - tdesc_add_field (type, "v2_int64", field_type); - field_type = tdesc_named_type (feature, "uint128"); - tdesc_add_field (type, "uint128", field_type); - - type = tdesc_create_flags (feature, "i386_mxcsr", 4); - tdesc_add_flag (type, 0, "IE"); - tdesc_add_flag (type, 1, "DE"); - tdesc_add_flag (type, 2, "ZE"); - tdesc_add_flag (type, 3, "OE"); - tdesc_add_flag (type, 4, "UE"); - tdesc_add_flag (type, 5, "PE"); - tdesc_add_flag (type, 6, "DAZ"); - tdesc_add_flag (type, 7, "IM"); - tdesc_add_flag (type, 8, "DM"); - tdesc_add_flag (type, 9, "ZM"); - tdesc_add_flag (type, 10, "OM"); - tdesc_add_flag (type, 11, "UM"); - tdesc_add_flag (type, 12, "PM"); - tdesc_add_flag (type, 15, "FZ"); - - tdesc_create_reg (feature, "xmm0", 40, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm1", 41, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm2", 42, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm3", 43, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm4", 44, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm5", 45, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm6", 46, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm7", 47, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm8", 48, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm9", 49, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm10", 50, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm11", 51, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm12", 52, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm13", 53, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm14", 54, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx512"); - field_type = tdesc_named_type (feature, "ieee_single"); - tdesc_create_vector (feature, "v4f", field_type, 4); - - field_type = tdesc_named_type (feature, "ieee_double"); - tdesc_create_vector (feature, "v2d", field_type, 2); - - field_type = tdesc_named_type (feature, "int8"); - tdesc_create_vector (feature, "v16i8", field_type, 16); - - field_type = tdesc_named_type (feature, "int16"); - tdesc_create_vector (feature, "v8i16", field_type, 8); - - field_type = tdesc_named_type (feature, "int32"); - tdesc_create_vector (feature, "v4i32", field_type, 4); - - field_type = tdesc_named_type (feature, "int64"); - tdesc_create_vector (feature, "v2i64", field_type, 2); - - type = tdesc_create_union (feature, "vec128"); - field_type = tdesc_named_type (feature, "v4f"); - tdesc_add_field (type, "v4_float", field_type); - field_type = tdesc_named_type (feature, "v2d"); - tdesc_add_field (type, "v2_double", field_type); - field_type = tdesc_named_type (feature, "v16i8"); - tdesc_add_field (type, "v16_int8", field_type); - field_type = tdesc_named_type (feature, "v8i16"); - tdesc_add_field (type, "v8_int16", field_type); - field_type = tdesc_named_type (feature, "v4i32"); - tdesc_add_field (type, "v4_int32", field_type); - field_type = tdesc_named_type (feature, "v2i64"); - tdesc_add_field (type, "v2_int64", field_type); - field_type = tdesc_named_type (feature, "uint128"); - tdesc_add_field (type, "uint128", field_type); - - field_type = tdesc_named_type (feature, "uint128"); - tdesc_create_vector (feature, "v2ui128", field_type, 2); - - tdesc_create_reg (feature, "xmm16", 73, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm17", 74, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm18", 75, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm19", 76, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm20", 77, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm21", 78, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm22", 79, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm23", 80, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm24", 81, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm25", 82, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm26", 83, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm27", 84, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm28", 85, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm29", 86, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm30", 87, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm31", 88, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "ymm16h", 89, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm17h", 90, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm18h", 91, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm19h", 92, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm20h", 93, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm21h", 94, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm22h", 95, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm23h", 96, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm24h", 97, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm25h", 98, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm26h", 99, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm27h", 100, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm28h", 101, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm29h", 102, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm30h", 103, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm31h", 104, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "k0", 105, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k1", 106, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k2", 107, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k3", 108, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k4", 109, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k5", 110, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k6", 111, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "k7", 112, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "zmm0h", 113, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm1h", 114, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm2h", 115, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm3h", 116, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm4h", 117, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm5h", 118, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm6h", 119, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm7h", 120, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm8h", 121, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm9h", 122, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm10h", 123, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm11h", 124, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm12h", 125, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm13h", 126, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm14h", 127, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm15h", 128, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm16h", 129, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm17h", 130, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm18h", 131, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm19h", 132, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm20h", 133, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm21h", 134, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm22h", 135, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm23h", 136, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm24h", 137, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm25h", 138, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm26h", 139, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm27h", 140, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm28h", 141, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm29h", 142, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm30h", 143, 1, NULL, 256, "v2ui128"); - tdesc_create_reg (feature, "zmm31h", 144, 1, NULL, 256, "v2ui128"); - - tdesc_x32_avx_avx512 = result; -} diff --git a/gdb/features/i386/x32-avx-avx512.xml b/gdb/features/i386/x32-avx-avx512.xml deleted file mode 100644 index eb69dfe..0000000 --- a/gdb/features/i386/x32-avx-avx512.xml +++ /dev/null @@ -1,17 +0,0 @@ -<?xml version="1.0"?> -<!-- Copyright (C) 2014-2017 Free Software Foundation, Inc. - - Copying and distribution of this file, with or without modification, - are permitted in any medium without royalty provided the copyright - notice and this notice are preserved. --> - -<!-- X32 with AVX, AVX512 --> - -<!DOCTYPE target SYSTEM "gdb-target.dtd"> -<target> - <architecture>i386:x64-32</architecture> - <xi:include href="x32-core.xml"/> - <xi:include href="64bit-sse.xml"/> - <xi:include href="64bit-avx.xml"/> - <xi:include href="64bit-avx512.xml"/> -</target> diff --git a/gdb/features/i386/x32-avx-linux.c b/gdb/features/i386/x32-avx-linux.c index 8406815..211d138 100644 --- a/gdb/features/i386/x32-avx-linux.c +++ b/gdb/features/i386/x32-avx-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_x32_avx_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/x32-avx.c b/gdb/features/i386/x32-avx.c deleted file mode 100644 index 7f62e8f..0000000 --- a/gdb/features/i386/x32-avx.c +++ /dev/null @@ -1,168 +0,0 @@ -/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: - Original: x32-avx.xml */ - -#include "defs.h" -#include "osabi.h" -#include "target-descriptions.h" - -struct target_desc *tdesc_x32_avx; -static void -initialize_tdesc_x32_avx (void) -{ - struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); - type = tdesc_create_flags (feature, "i386_eflags", 4); - tdesc_add_flag (type, 0, "CF"); - tdesc_add_flag (type, 1, ""); - tdesc_add_flag (type, 2, "PF"); - tdesc_add_flag (type, 4, "AF"); - tdesc_add_flag (type, 6, "ZF"); - tdesc_add_flag (type, 7, "SF"); - tdesc_add_flag (type, 8, "TF"); - tdesc_add_flag (type, 9, "IF"); - tdesc_add_flag (type, 10, "DF"); - tdesc_add_flag (type, 11, "OF"); - tdesc_add_flag (type, 14, "NT"); - tdesc_add_flag (type, 16, "RF"); - tdesc_add_flag (type, 17, "VM"); - tdesc_add_flag (type, 18, "AC"); - tdesc_add_flag (type, 19, "VIF"); - tdesc_add_flag (type, 20, "VIP"); - tdesc_add_flag (type, 21, "ID"); - - tdesc_create_reg (feature, "rax", 0, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbx", 1, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rcx", 2, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdx", 3, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsi", 4, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdi", 5, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbp", 6, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsp", 7, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r8", 8, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r9", 9, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r10", 10, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r11", 11, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r12", 12, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r13", 13, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r14", 14, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r15", 15, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rip", 16, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "eflags", 17, 1, NULL, 32, "i386_eflags"); - tdesc_create_reg (feature, "cs", 18, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ss", 19, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ds", 20, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "es", 21, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "fs", 22, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "gs", 23, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "st0", 24, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st1", 25, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st2", 26, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st3", 27, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st4", 28, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st5", 29, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st6", 30, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st7", 31, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "fctrl", 32, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fstat", 33, 1, "float", 32, "int"); - tdesc_create_reg (feature, "ftag", 34, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fiseg", 35, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fioff", 36, 1, "float", 32, "int"); - tdesc_create_reg (feature, "foseg", 37, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fooff", 38, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fop", 39, 1, "float", 32, "int"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.sse"); - field_type = tdesc_named_type (feature, "ieee_single"); - tdesc_create_vector (feature, "v4f", field_type, 4); - - field_type = tdesc_named_type (feature, "ieee_double"); - tdesc_create_vector (feature, "v2d", field_type, 2); - - field_type = tdesc_named_type (feature, "int8"); - tdesc_create_vector (feature, "v16i8", field_type, 16); - - field_type = tdesc_named_type (feature, "int16"); - tdesc_create_vector (feature, "v8i16", field_type, 8); - - field_type = tdesc_named_type (feature, "int32"); - tdesc_create_vector (feature, "v4i32", field_type, 4); - - field_type = tdesc_named_type (feature, "int64"); - tdesc_create_vector (feature, "v2i64", field_type, 2); - - type = tdesc_create_union (feature, "vec128"); - field_type = tdesc_named_type (feature, "v4f"); - tdesc_add_field (type, "v4_float", field_type); - field_type = tdesc_named_type (feature, "v2d"); - tdesc_add_field (type, "v2_double", field_type); - field_type = tdesc_named_type (feature, "v16i8"); - tdesc_add_field (type, "v16_int8", field_type); - field_type = tdesc_named_type (feature, "v8i16"); - tdesc_add_field (type, "v8_int16", field_type); - field_type = tdesc_named_type (feature, "v4i32"); - tdesc_add_field (type, "v4_int32", field_type); - field_type = tdesc_named_type (feature, "v2i64"); - tdesc_add_field (type, "v2_int64", field_type); - field_type = tdesc_named_type (feature, "uint128"); - tdesc_add_field (type, "uint128", field_type); - - type = tdesc_create_flags (feature, "i386_mxcsr", 4); - tdesc_add_flag (type, 0, "IE"); - tdesc_add_flag (type, 1, "DE"); - tdesc_add_flag (type, 2, "ZE"); - tdesc_add_flag (type, 3, "OE"); - tdesc_add_flag (type, 4, "UE"); - tdesc_add_flag (type, 5, "PE"); - tdesc_add_flag (type, 6, "DAZ"); - tdesc_add_flag (type, 7, "IM"); - tdesc_add_flag (type, 8, "DM"); - tdesc_add_flag (type, 9, "ZM"); - tdesc_add_flag (type, 10, "OM"); - tdesc_add_flag (type, 11, "UM"); - tdesc_add_flag (type, 12, "PM"); - tdesc_add_flag (type, 15, "FZ"); - - tdesc_create_reg (feature, "xmm0", 40, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm1", 41, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm2", 42, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm3", 43, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm4", 44, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm5", 45, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm6", 46, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm7", 47, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm8", 48, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm9", 49, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm10", 50, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm11", 51, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm12", 52, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm13", 53, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm14", 54, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx"); - tdesc_create_reg (feature, "ymm0h", 57, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm1h", 58, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm2h", 59, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm3h", 60, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm4h", 61, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm5h", 62, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm6h", 63, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm7h", 64, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm8h", 65, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm9h", 66, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm10h", 67, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm11h", 68, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm12h", 69, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm13h", 70, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm14h", 71, 1, NULL, 128, "uint128"); - tdesc_create_reg (feature, "ymm15h", 72, 1, NULL, 128, "uint128"); - - tdesc_x32_avx = result; -} diff --git a/gdb/features/i386/x32-avx.xml b/gdb/features/i386/x32-avx.xml deleted file mode 100644 index d2047ea..0000000 --- a/gdb/features/i386/x32-avx.xml +++ /dev/null @@ -1,16 +0,0 @@ -<?xml version="1.0"?> -<!-- Copyright (C) 2012-2017 Free Software Foundation, Inc. - - Copying and distribution of this file, with or without modification, - are permitted in any medium without royalty provided the copyright - notice and this notice are preserved. --> - -<!-- X32 with AVX --> - -<!DOCTYPE target SYSTEM "gdb-target.dtd"> -<target> - <architecture>i386:x64-32</architecture> - <xi:include href="x32-core.xml"/> - <xi:include href="64bit-sse.xml"/> - <xi:include href="64bit-avx.xml"/> -</target> diff --git a/gdb/features/i386/x32-linux.c b/gdb/features/i386/x32-linux.c index ae49549..05d502b 100644 --- a/gdb/features/i386/x32-linux.c +++ b/gdb/features/i386/x32-linux.c @@ -10,15 +10,15 @@ static void initialize_tdesc_x32_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); + struct tdesc_type *field_type; + struct tdesc_type *type; type = tdesc_create_flags (feature, "i386_eflags", 4); tdesc_add_flag (type, 0, "CF"); tdesc_add_flag (type, 1, ""); diff --git a/gdb/features/i386/x32.c b/gdb/features/i386/x32.c deleted file mode 100644 index 6005d99..0000000 --- a/gdb/features/i386/x32.c +++ /dev/null @@ -1,150 +0,0 @@ -/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro: - Original: x32.xml */ - -#include "defs.h" -#include "osabi.h" -#include "target-descriptions.h" - -struct target_desc *tdesc_x32; -static void -initialize_tdesc_x32 (void) -{ - struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - - set_tdesc_architecture (result, bfd_scan_arch ("i386:x64-32")); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core"); - type = tdesc_create_flags (feature, "i386_eflags", 4); - tdesc_add_flag (type, 0, "CF"); - tdesc_add_flag (type, 1, ""); - tdesc_add_flag (type, 2, "PF"); - tdesc_add_flag (type, 4, "AF"); - tdesc_add_flag (type, 6, "ZF"); - tdesc_add_flag (type, 7, "SF"); - tdesc_add_flag (type, 8, "TF"); - tdesc_add_flag (type, 9, "IF"); - tdesc_add_flag (type, 10, "DF"); - tdesc_add_flag (type, 11, "OF"); - tdesc_add_flag (type, 14, "NT"); - tdesc_add_flag (type, 16, "RF"); - tdesc_add_flag (type, 17, "VM"); - tdesc_add_flag (type, 18, "AC"); - tdesc_add_flag (type, 19, "VIF"); - tdesc_add_flag (type, 20, "VIP"); - tdesc_add_flag (type, 21, "ID"); - - tdesc_create_reg (feature, "rax", 0, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbx", 1, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rcx", 2, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdx", 3, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsi", 4, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rdi", 5, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rbp", 6, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rsp", 7, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r8", 8, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r9", 9, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r10", 10, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r11", 11, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r12", 12, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r13", 13, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r14", 14, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "r15", 15, 1, NULL, 64, "int64"); - tdesc_create_reg (feature, "rip", 16, 1, NULL, 64, "uint64"); - tdesc_create_reg (feature, "eflags", 17, 1, NULL, 32, "i386_eflags"); - tdesc_create_reg (feature, "cs", 18, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ss", 19, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "ds", 20, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "es", 21, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "fs", 22, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "gs", 23, 1, NULL, 32, "int32"); - tdesc_create_reg (feature, "st0", 24, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st1", 25, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st2", 26, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st3", 27, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st4", 28, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st5", 29, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st6", 30, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "st7", 31, 1, NULL, 80, "i387_ext"); - tdesc_create_reg (feature, "fctrl", 32, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fstat", 33, 1, "float", 32, "int"); - tdesc_create_reg (feature, "ftag", 34, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fiseg", 35, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fioff", 36, 1, "float", 32, "int"); - tdesc_create_reg (feature, "foseg", 37, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fooff", 38, 1, "float", 32, "int"); - tdesc_create_reg (feature, "fop", 39, 1, "float", 32, "int"); - - feature = tdesc_create_feature (result, "org.gnu.gdb.i386.sse"); - field_type = tdesc_named_type (feature, "ieee_single"); - tdesc_create_vector (feature, "v4f", field_type, 4); - - field_type = tdesc_named_type (feature, "ieee_double"); - tdesc_create_vector (feature, "v2d", field_type, 2); - - field_type = tdesc_named_type (feature, "int8"); - tdesc_create_vector (feature, "v16i8", field_type, 16); - - field_type = tdesc_named_type (feature, "int16"); - tdesc_create_vector (feature, "v8i16", field_type, 8); - - field_type = tdesc_named_type (feature, "int32"); - tdesc_create_vector (feature, "v4i32", field_type, 4); - - field_type = tdesc_named_type (feature, "int64"); - tdesc_create_vector (feature, "v2i64", field_type, 2); - - type = tdesc_create_union (feature, "vec128"); - field_type = tdesc_named_type (feature, "v4f"); - tdesc_add_field (type, "v4_float", field_type); - field_type = tdesc_named_type (feature, "v2d"); - tdesc_add_field (type, "v2_double", field_type); - field_type = tdesc_named_type (feature, "v16i8"); - tdesc_add_field (type, "v16_int8", field_type); - field_type = tdesc_named_type (feature, "v8i16"); - tdesc_add_field (type, "v8_int16", field_type); - field_type = tdesc_named_type (feature, "v4i32"); - tdesc_add_field (type, "v4_int32", field_type); - field_type = tdesc_named_type (feature, "v2i64"); - tdesc_add_field (type, "v2_int64", field_type); - field_type = tdesc_named_type (feature, "uint128"); - tdesc_add_field (type, "uint128", field_type); - - type = tdesc_create_flags (feature, "i386_mxcsr", 4); - tdesc_add_flag (type, 0, "IE"); - tdesc_add_flag (type, 1, "DE"); - tdesc_add_flag (type, 2, "ZE"); - tdesc_add_flag (type, 3, "OE"); - tdesc_add_flag (type, 4, "UE"); - tdesc_add_flag (type, 5, "PE"); - tdesc_add_flag (type, 6, "DAZ"); - tdesc_add_flag (type, 7, "IM"); - tdesc_add_flag (type, 8, "DM"); - tdesc_add_flag (type, 9, "ZM"); - tdesc_add_flag (type, 10, "OM"); - tdesc_add_flag (type, 11, "UM"); - tdesc_add_flag (type, 12, "PM"); - tdesc_add_flag (type, 15, "FZ"); - - tdesc_create_reg (feature, "xmm0", 40, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm1", 41, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm2", 42, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm3", 43, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm4", 44, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm5", 45, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm6", 46, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm7", 47, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm8", 48, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm9", 49, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm10", 50, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm11", 51, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm12", 52, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm13", 53, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm14", 54, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "xmm15", 55, 1, NULL, 128, "vec128"); - tdesc_create_reg (feature, "mxcsr", 56, 1, "vector", 32, "i386_mxcsr"); - - tdesc_x32 = result; -} diff --git a/gdb/features/i386/x32.xml b/gdb/features/i386/x32.xml deleted file mode 100644 index 5d19bcf..0000000 --- a/gdb/features/i386/x32.xml +++ /dev/null @@ -1,15 +0,0 @@ -<?xml version="1.0"?> -<!-- Copyright (C) 2012-2017 Free Software Foundation, Inc. - - Copying and distribution of this file, with or without modification, - are permitted in any medium without royalty provided the copyright - notice and this notice are preserved. --> - -<!-- X32 --> - -<!DOCTYPE target SYSTEM "gdb-target.dtd"> -<target> - <architecture>i386:x64-32</architecture> - <xi:include href="x32-core.xml"/> - <xi:include href="64bit-sse.xml"/> -</target> diff --git a/gdb/features/mips-dsp-linux.c b/gdb/features/mips-dsp-linux.c index 80ceb22..26e9c6b 100644 --- a/gdb/features/mips-dsp-linux.c +++ b/gdb/features/mips-dsp-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_mips_dsp_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("mips")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.mips.cpu"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/mips-linux.c b/gdb/features/mips-linux.c index c990119..c9ad3ca 100644 --- a/gdb/features/mips-linux.c +++ b/gdb/features/mips-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_mips_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("mips")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.mips.cpu"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/mips64-dsp-linux.c b/gdb/features/mips64-dsp-linux.c index bc09078..05317b7 100644 --- a/gdb/features/mips64-dsp-linux.c +++ b/gdb/features/mips64-dsp-linux.c @@ -10,10 +10,10 @@ static void initialize_tdesc_mips64_dsp_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("mips")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.mips.cpu"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "int"); diff --git a/gdb/features/mips64-linux.c b/gdb/features/mips64-linux.c index 2ecda9b..4814152 100644 --- a/gdb/features/mips64-linux.c +++ b/gdb/features/mips64-linux.c @@ -10,10 +10,10 @@ static void initialize_tdesc_mips64_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("mips")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.mips.cpu"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "int"); diff --git a/gdb/features/nds32.c b/gdb/features/nds32.c index 21f63f5..89b246b 100644 --- a/gdb/features/nds32.c +++ b/gdb/features/nds32.c @@ -10,10 +10,10 @@ static void initialize_tdesc_nds32 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("n1h")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.nds32.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/nios2-linux.c b/gdb/features/nios2-linux.c index 3288f79..0368567 100644 --- a/gdb/features/nios2-linux.c +++ b/gdb/features/nios2-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_nios2_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("nios2")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.nios2.cpu"); tdesc_create_reg (feature, "zero", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "at", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/nios2.c b/gdb/features/nios2.c index 0cedc12..705f499 100644 --- a/gdb/features/nios2.c +++ b/gdb/features/nios2.c @@ -10,10 +10,10 @@ static void initialize_tdesc_nios2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("nios2")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.nios2.cpu"); tdesc_create_reg (feature, "zero", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "at", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-32.c b/gdb/features/rs6000/powerpc-32.c index 5ee5d9c..39f5b14 100644 --- a/gdb/features/rs6000/powerpc-32.c +++ b/gdb/features/rs6000/powerpc-32.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_32 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-32l.c b/gdb/features/rs6000/powerpc-32l.c index 971fd4b..8089c04 100644 --- a/gdb/features/rs6000/powerpc-32l.c +++ b/gdb/features/rs6000/powerpc-32l.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-64.c b/gdb/features/rs6000/powerpc-64.c index 160d122..a9760a3 100644 --- a/gdb/features/rs6000/powerpc-64.c +++ b/gdb/features/rs6000/powerpc-64.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); diff --git a/gdb/features/rs6000/powerpc-64l.c b/gdb/features/rs6000/powerpc-64l.c index 16a766e..408794e 100644 --- a/gdb/features/rs6000/powerpc-64l.c +++ b/gdb/features/rs6000/powerpc-64l.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); diff --git a/gdb/features/rs6000/powerpc-7400.c b/gdb/features/rs6000/powerpc-7400.c index 69d20c4..32b6995 100644 --- a/gdb/features/rs6000/powerpc-7400.c +++ b/gdb/features/rs6000/powerpc-7400.c @@ -11,8 +11,6 @@ initialize_tdesc_powerpc_7400 (void) { struct target_desc *result = allocate_target_description (); struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); @@ -140,6 +138,7 @@ initialize_tdesc_powerpc_7400 (void) tdesc_create_reg (feature, "ear", 118, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -152,6 +151,7 @@ initialize_tdesc_powerpc_7400 (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-altivec32.c b/gdb/features/rs6000/powerpc-altivec32.c index 285e87d..e97132e 100644 --- a/gdb/features/rs6000/powerpc-altivec32.c +++ b/gdb/features/rs6000/powerpc-altivec32.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_altivec32 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -92,6 +90,7 @@ initialize_tdesc_powerpc_altivec32 (void) tdesc_create_reg (feature, "fpscr", 70, 1, "float", 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -104,6 +103,7 @@ initialize_tdesc_powerpc_altivec32 (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-altivec32l.c b/gdb/features/rs6000/powerpc-altivec32l.c index 447ed47..a9445d9 100644 --- a/gdb/features/rs6000/powerpc-altivec32l.c +++ b/gdb/features/rs6000/powerpc-altivec32l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_altivec32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_altivec32l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_altivec32l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-altivec64.c b/gdb/features/rs6000/powerpc-altivec64.c index 1e9a61d..3b626a9 100644 --- a/gdb/features/rs6000/powerpc-altivec64.c +++ b/gdb/features/rs6000/powerpc-altivec64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_altivec64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -92,6 +90,7 @@ initialize_tdesc_powerpc_altivec64 (void) tdesc_create_reg (feature, "fpscr", 70, 1, "float", 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -104,6 +103,7 @@ initialize_tdesc_powerpc_altivec64 (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-altivec64l.c b/gdb/features/rs6000/powerpc-altivec64l.c index 10ecd8a..cca5353 100644 --- a/gdb/features/rs6000/powerpc-altivec64l.c +++ b/gdb/features/rs6000/powerpc-altivec64l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_altivec64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_altivec64l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 64, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_altivec64l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-cell32l.c b/gdb/features/rs6000/powerpc-cell32l.c index 7d33dc2..c615b8d 100644 --- a/gdb/features/rs6000/powerpc-cell32l.c +++ b/gdb/features/rs6000/powerpc-cell32l.c @@ -10,14 +10,12 @@ static void initialize_tdesc_powerpc_cell32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); tdesc_add_compatible (result, bfd_scan_arch ("spu:256K")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -98,6 +96,7 @@ initialize_tdesc_powerpc_cell32l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -110,6 +109,7 @@ initialize_tdesc_powerpc_cell32l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-cell64l.c b/gdb/features/rs6000/powerpc-cell64l.c index 6054c26..5040e5e 100644 --- a/gdb/features/rs6000/powerpc-cell64l.c +++ b/gdb/features/rs6000/powerpc-cell64l.c @@ -10,14 +10,12 @@ static void initialize_tdesc_powerpc_cell64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); tdesc_add_compatible (result, bfd_scan_arch ("spu:256K")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -98,6 +96,7 @@ initialize_tdesc_powerpc_cell64l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 64, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -110,6 +109,7 @@ initialize_tdesc_powerpc_cell64l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-e500.c b/gdb/features/rs6000/powerpc-e500.c index aaca3a7..4466bc7 100644 --- a/gdb/features/rs6000/powerpc-e500.c +++ b/gdb/features/rs6000/powerpc-e500.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_e500 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:e500")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-e500l.c b/gdb/features/rs6000/powerpc-e500l.c index de03862..61acbf3 100644 --- a/gdb/features/rs6000/powerpc-e500l.c +++ b/gdb/features/rs6000/powerpc-e500l.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_e500l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:e500")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-isa205-32l.c b/gdb/features/rs6000/powerpc-isa205-32l.c index 1b5bd6d..de6548f 100644 --- a/gdb/features/rs6000/powerpc-isa205-32l.c +++ b/gdb/features/rs6000/powerpc-isa205-32l.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_isa205_32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/rs6000/powerpc-isa205-64l.c b/gdb/features/rs6000/powerpc-isa205-64l.c index 31bfc87..cd3b2c1 100644 --- a/gdb/features/rs6000/powerpc-isa205-64l.c +++ b/gdb/features/rs6000/powerpc-isa205-64l.c @@ -10,10 +10,10 @@ static void initialize_tdesc_powerpc_isa205_64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); diff --git a/gdb/features/rs6000/powerpc-isa205-altivec32l.c b/gdb/features/rs6000/powerpc-isa205-altivec32l.c index 6c216ce..943d02d 100644 --- a/gdb/features/rs6000/powerpc-isa205-altivec32l.c +++ b/gdb/features/rs6000/powerpc-isa205-altivec32l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_isa205_altivec32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_isa205_altivec32l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_isa205_altivec32l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-isa205-altivec64l.c b/gdb/features/rs6000/powerpc-isa205-altivec64l.c index 2c206aa..d454bac 100644 --- a/gdb/features/rs6000/powerpc-isa205-altivec64l.c +++ b/gdb/features/rs6000/powerpc-isa205-altivec64l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_isa205_altivec64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_isa205_altivec64l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 64, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_isa205_altivec64l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-isa205-vsx32l.c b/gdb/features/rs6000/powerpc-isa205-vsx32l.c index 4659ce1..09fd5ce 100644 --- a/gdb/features/rs6000/powerpc-isa205-vsx32l.c +++ b/gdb/features/rs6000/powerpc-isa205-vsx32l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_isa205_vsx32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_isa205_vsx32l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_isa205_vsx32l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-isa205-vsx64l.c b/gdb/features/rs6000/powerpc-isa205-vsx64l.c index 64b12b9..d295ab7 100644 --- a/gdb/features/rs6000/powerpc-isa205-vsx64l.c +++ b/gdb/features/rs6000/powerpc-isa205-vsx64l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_isa205_vsx64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_isa205_vsx64l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 64, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_isa205_vsx64l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-vsx32.c b/gdb/features/rs6000/powerpc-vsx32.c index ba1fcb6..8cf7562 100644 --- a/gdb/features/rs6000/powerpc-vsx32.c +++ b/gdb/features/rs6000/powerpc-vsx32.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_vsx32 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -92,6 +90,7 @@ initialize_tdesc_powerpc_vsx32 (void) tdesc_create_reg (feature, "fpscr", 70, 1, "float", 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -104,6 +103,7 @@ initialize_tdesc_powerpc_vsx32 (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-vsx32l.c b/gdb/features/rs6000/powerpc-vsx32l.c index 013e392..e8c1881 100644 --- a/gdb/features/rs6000/powerpc-vsx32l.c +++ b/gdb/features/rs6000/powerpc-vsx32l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_vsx32l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_vsx32l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_vsx32l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-vsx64.c b/gdb/features/rs6000/powerpc-vsx64.c index ca02323..30953c5 100644 --- a/gdb/features/rs6000/powerpc-vsx64.c +++ b/gdb/features/rs6000/powerpc-vsx64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_vsx64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -92,6 +90,7 @@ initialize_tdesc_powerpc_vsx64 (void) tdesc_create_reg (feature, "fpscr", 70, 1, "float", 32, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -104,6 +103,7 @@ initialize_tdesc_powerpc_vsx64 (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/powerpc-vsx64l.c b/gdb/features/rs6000/powerpc-vsx64l.c index 31bb224..5f12650 100644 --- a/gdb/features/rs6000/powerpc-vsx64l.c +++ b/gdb/features/rs6000/powerpc-vsx64l.c @@ -10,12 +10,10 @@ static void initialize_tdesc_powerpc_vsx64l (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common64")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 64, "uint64"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 64, "uint64"); @@ -96,6 +94,7 @@ initialize_tdesc_powerpc_vsx64l (void) tdesc_create_reg (feature, "trap", 72, 1, NULL, 64, "int"); feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -108,6 +107,7 @@ initialize_tdesc_powerpc_vsx64l (void) field_type = tdesc_named_type (feature, "int8"); tdesc_create_vector (feature, "v16i8", field_type, 16); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "uint128"); tdesc_add_field (type, "uint128", field_type); diff --git a/gdb/features/rs6000/rs6000.c b/gdb/features/rs6000/rs6000.c index d4e93a5..709b5da 100644 --- a/gdb/features/rs6000/rs6000.c +++ b/gdb/features/rs6000/rs6000.c @@ -10,10 +10,10 @@ static void initialize_tdesc_rs6000 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("rs6000:6000")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.power.core"); tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int"); tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "int"); diff --git a/gdb/features/s390-linux32.c b/gdb/features/s390-linux32.c index 6d13094..01c136c 100644 --- a/gdb/features/s390-linux32.c +++ b/gdb/features/s390-linux32.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux32 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-linux32v1.c b/gdb/features/s390-linux32v1.c index f773fc1..65a4a50 100644 --- a/gdb/features/s390-linux32v1.c +++ b/gdb/features/s390-linux32v1.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux32v1 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-linux32v2.c b/gdb/features/s390-linux32v2.c index 2317752..b5d25ec 100644 --- a/gdb/features/s390-linux32v2.c +++ b/gdb/features/s390-linux32v2.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux32v2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-linux64.c b/gdb/features/s390-linux64.c index 3c7145b..531d3a1 100644 --- a/gdb/features/s390-linux64.c +++ b/gdb/features/s390-linux64.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-linux64v1.c b/gdb/features/s390-linux64v1.c index 72bd894..d75deca 100644 --- a/gdb/features/s390-linux64v1.c +++ b/gdb/features/s390-linux64v1.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux64v1 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-linux64v2.c b/gdb/features/s390-linux64v2.c index a1757da..bd10ee8 100644 --- a/gdb/features/s390-linux64v2.c +++ b/gdb/features/s390-linux64v2.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_linux64v2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-te-linux64.c b/gdb/features/s390-te-linux64.c index 0a3aedf..fe2020a 100644 --- a/gdb/features/s390-te-linux64.c +++ b/gdb/features/s390-te-linux64.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390_te_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); diff --git a/gdb/features/s390-tevx-linux64.c b/gdb/features/s390-tevx-linux64.c index 5bc3eec..d9b18d3 100644 --- a/gdb/features/s390-tevx-linux64.c +++ b/gdb/features/s390-tevx-linux64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_s390_tevx_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); @@ -117,6 +115,7 @@ initialize_tdesc_s390_tevx_linux64 (void) tdesc_create_reg (feature, "tr15", 89, 1, "tdb", 64, "uint64"); feature = tdesc_create_feature (result, "org.gnu.gdb.s390.vx"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -135,6 +134,7 @@ initialize_tdesc_s390_tevx_linux64 (void) field_type = tdesc_named_type (feature, "int64"); tdesc_create_vector (feature, "v2i64", field_type, 2); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "v4f"); tdesc_add_field (type, "v4_float", field_type); diff --git a/gdb/features/s390-vx-linux64.c b/gdb/features/s390-vx-linux64.c index c3ffa16..b2138dd 100644 --- a/gdb/features/s390-vx-linux64.c +++ b/gdb/features/s390-vx-linux64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_s390_vx_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("s390:31-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 32, "uint32"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 32, "uint32"); @@ -95,6 +93,7 @@ initialize_tdesc_s390_vx_linux64 (void) tdesc_create_reg (feature, "system_call", 69, 1, "system", 32, "uint32"); feature = tdesc_create_feature (result, "org.gnu.gdb.s390.vx"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -113,6 +112,7 @@ initialize_tdesc_s390_vx_linux64 (void) field_type = tdesc_named_type (feature, "int64"); tdesc_create_vector (feature, "v2i64", field_type, 2); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "v4f"); tdesc_add_field (type, "v4_float", field_type); diff --git a/gdb/features/s390x-linux64.c b/gdb/features/s390x-linux64.c index 04502c6..9d48ea3 100644 --- a/gdb/features/s390x-linux64.c +++ b/gdb/features/s390x-linux64.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390x_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); diff --git a/gdb/features/s390x-linux64v1.c b/gdb/features/s390x-linux64v1.c index 05bfd53..b95f1c4 100644 --- a/gdb/features/s390x-linux64v1.c +++ b/gdb/features/s390x-linux64v1.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390x_linux64v1 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); diff --git a/gdb/features/s390x-linux64v2.c b/gdb/features/s390x-linux64v2.c index 4108cc0..9aab89f 100644 --- a/gdb/features/s390x-linux64v2.c +++ b/gdb/features/s390x-linux64v2.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390x_linux64v2 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); diff --git a/gdb/features/s390x-te-linux64.c b/gdb/features/s390x-te-linux64.c index f75d900..babd3bd 100644 --- a/gdb/features/s390x-te-linux64.c +++ b/gdb/features/s390x-te-linux64.c @@ -10,10 +10,10 @@ static void initialize_tdesc_s390x_te_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); diff --git a/gdb/features/s390x-tevx-linux64.c b/gdb/features/s390x-tevx-linux64.c index 327cd23..02afd3a 100644 --- a/gdb/features/s390x-tevx-linux64.c +++ b/gdb/features/s390x-tevx-linux64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_s390x_tevx_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); @@ -101,6 +99,7 @@ initialize_tdesc_s390x_tevx_linux64 (void) tdesc_create_reg (feature, "tr15", 73, 1, "tdb", 64, "uint64"); feature = tdesc_create_feature (result, "org.gnu.gdb.s390.vx"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -119,6 +118,7 @@ initialize_tdesc_s390x_tevx_linux64 (void) field_type = tdesc_named_type (feature, "int64"); tdesc_create_vector (feature, "v2i64", field_type, 2); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "v4f"); tdesc_add_field (type, "v4_float", field_type); diff --git a/gdb/features/s390x-vx-linux64.c b/gdb/features/s390x-vx-linux64.c index e66da70..120db53 100644 --- a/gdb/features/s390x-vx-linux64.c +++ b/gdb/features/s390x-vx-linux64.c @@ -10,12 +10,10 @@ static void initialize_tdesc_s390x_vx_linux64 (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - struct tdesc_type *field_type; - struct tdesc_type *type; - set_tdesc_architecture (result, bfd_scan_arch ("s390:64-bit")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.s390.core"); tdesc_create_reg (feature, "pswm", 0, 1, "psw", 64, "uint64"); tdesc_create_reg (feature, "pswa", 1, 1, "psw", 64, "uint64"); @@ -79,6 +77,7 @@ initialize_tdesc_s390x_vx_linux64 (void) tdesc_create_reg (feature, "system_call", 53, 1, "system", 32, "uint32"); feature = tdesc_create_feature (result, "org.gnu.gdb.s390.vx"); + struct tdesc_type *field_type; field_type = tdesc_named_type (feature, "ieee_single"); tdesc_create_vector (feature, "v4f", field_type, 4); @@ -97,6 +96,7 @@ initialize_tdesc_s390x_vx_linux64 (void) field_type = tdesc_named_type (feature, "int64"); tdesc_create_vector (feature, "v2i64", field_type, 2); + struct tdesc_type *type; type = tdesc_create_union (feature, "vec128"); field_type = tdesc_named_type (feature, "v4f"); tdesc_add_field (type, "v4_float", field_type); diff --git a/gdb/features/tic6x-c62x-linux.c b/gdb/features/tic6x-c62x-linux.c index 8dd426d..86b905d 100644 --- a/gdb/features/tic6x-c62x-linux.c +++ b/gdb/features/tic6x-c62x-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_tic6x_c62x_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/tic6x-c62x.c b/gdb/features/tic6x-c62x.c index 2089aaf..7dbf615 100644 --- a/gdb/features/tic6x-c62x.c +++ b/gdb/features/tic6x-c62x.c @@ -10,10 +10,10 @@ static void initialize_tdesc_tic6x_c62x (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/tic6x-c64x-linux.c b/gdb/features/tic6x-c64x-linux.c index 2752358..b52048f 100644 --- a/gdb/features/tic6x-c64x-linux.c +++ b/gdb/features/tic6x-c64x-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_tic6x_c64x_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/tic6x-c64x.c b/gdb/features/tic6x-c64x.c index 0feda24..618f802 100644 --- a/gdb/features/tic6x-c64x.c +++ b/gdb/features/tic6x-c64x.c @@ -10,10 +10,10 @@ static void initialize_tdesc_tic6x_c64x (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/tic6x-c64xp-linux.c b/gdb/features/tic6x-c64xp-linux.c index c1bee4c..ca8c505 100644 --- a/gdb/features/tic6x-c64xp-linux.c +++ b/gdb/features/tic6x-c64xp-linux.c @@ -10,12 +10,12 @@ static void initialize_tdesc_tic6x_c64xp_linux (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); set_tdesc_osabi (result, osabi_from_tdesc_string ("GNU/Linux")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); diff --git a/gdb/features/tic6x-c64xp.c b/gdb/features/tic6x-c64xp.c index 160b854..4ca5125 100644 --- a/gdb/features/tic6x-c64xp.c +++ b/gdb/features/tic6x-c64xp.c @@ -10,10 +10,10 @@ static void initialize_tdesc_tic6x_c64xp (void) { struct target_desc *result = allocate_target_description (); - struct tdesc_feature *feature; - set_tdesc_architecture (result, bfd_scan_arch ("tic6x")); + struct tdesc_feature *feature; + feature = tdesc_create_feature (result, "org.gnu.gdb.tic6x.core"); tdesc_create_reg (feature, "A0", 0, 1, NULL, 32, "uint32"); tdesc_create_reg (feature, "A1", 1, 1, NULL, 32, "uint32"); |