diff options
Diffstat (limited to 'gas')
79 files changed, 1019 insertions, 40 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog index f8669b5..1ac99b9 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,19 @@ +2009-01-26 Andrew Stubbs <ams@codesourcery.com> + + * config/tc-arm.c (attributes_set_explicitly): New array. + (s_arm_eabi_attribute): Check return value from s_vendor_attribute. + (cpu_arch): Add ARM_ARCH_V5T. + (aeabi_set_attribute_int): New function. + (aeabi_set_attribute_string): New function. + (aeabi_set_public_attributes): Set attributes according to the user's + intentions, rather than the actual state of the binary. + Use aeabi_set_attribute_int and aeabi_set_attribute_string instead of + bfd_elf_add_proc_attr_int and bfd_elf_add_proc_attr_string. + Support WMMXv2. Use attribute names instead of numbers. + * read.c (s_vendor_attribute): Change return type to int. + Return the tag number that was set. + * read.h (s_vendor_attribute): Change return type to int. + 2009-01-26 Eric B. Weddington <eric.weddington@atmel.com> PR 9789 diff --git a/gas/config/tc-arm.c b/gas/config/tc-arm.c index 0cefbdb..e97e0a3 100644 --- a/gas/config/tc-arm.c +++ b/gas/config/tc-arm.c @@ -241,6 +241,8 @@ static int meabi_flags = EABI_DEFAULT; static int meabi_flags = EF_ARM_EABI_UNKNOWN; # endif +static int attributes_set_explicitly[NUM_KNOWN_OBJ_ATTRIBUTES]; + bfd_boolean arm_is_eabi (void) { @@ -3884,7 +3886,10 @@ s_arm_unwind_raw (int ignored ATTRIBUTE_UNUSED) static void s_arm_eabi_attribute (int ignored ATTRIBUTE_UNUSED) { - s_vendor_attribute (OBJ_ATTR_PROC); + int tag = s_vendor_attribute (OBJ_ATTR_PROC); + + if (tag < NUM_KNOWN_OBJ_ATTRIBUTES) + attributes_set_explicitly[tag] = 1; } #endif /* OBJ_ELF */ @@ -20716,6 +20721,7 @@ static const cpu_arch_ver_table cpu_arch_ver[] = {1, ARM_ARCH_V4}, {2, ARM_ARCH_V4T}, {3, ARM_ARCH_V5}, + {3, ARM_ARCH_V5T}, {4, ARM_ARCH_V5TE}, {5, ARM_ARCH_V5TEJ}, {6, ARM_ARCH_V6}, @@ -20729,6 +20735,25 @@ static const cpu_arch_ver_table cpu_arch_ver[] = {0, ARM_ARCH_NONE} }; +/* Set an attribute if it has not already been set by the user. */ +static void +aeabi_set_attribute_int (int tag, int value) +{ + if (tag < 1 + || tag >= NUM_KNOWN_OBJ_ATTRIBUTES + || !attributes_set_explicitly[tag]) + bfd_elf_add_proc_attr_int (stdoutput, tag, value); +} + +static void +aeabi_set_attribute_string (int tag, const char *value) +{ + if (tag < 1 + || tag >= NUM_KNOWN_OBJ_ATTRIBUTES + || !attributes_set_explicitly[tag]) + bfd_elf_add_proc_attr_string (stdoutput, tag, value); +} + /* Set the public EABI object attributes. */ static void aeabi_set_public_attributes (void) @@ -20775,49 +20800,47 @@ aeabi_set_public_attributes (void) for (i = 0; p[i]; i++) p[i] = TOUPPER (p[i]); } - bfd_elf_add_proc_attr_string (stdoutput, 5, p); + aeabi_set_attribute_string (Tag_CPU_name, p); } /* Tag_CPU_arch. */ - bfd_elf_add_proc_attr_int (stdoutput, 6, arch); + aeabi_set_attribute_int (Tag_CPU_arch, arch); /* Tag_CPU_arch_profile. */ if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7a)) - bfd_elf_add_proc_attr_int (stdoutput, 7, 'A'); + aeabi_set_attribute_int (Tag_CPU_arch_profile, 'A'); else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7r)) - bfd_elf_add_proc_attr_int (stdoutput, 7, 'R'); + aeabi_set_attribute_int (Tag_CPU_arch_profile, 'R'); else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_m)) - bfd_elf_add_proc_attr_int (stdoutput, 7, 'M'); + aeabi_set_attribute_int (Tag_CPU_arch_profile, 'M'); /* Tag_ARM_ISA_use. */ - if (ARM_CPU_HAS_FEATURE (arm_arch_used, arm_arch_full)) - bfd_elf_add_proc_attr_int (stdoutput, 8, 1); + if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v1) + || arch == 0) + aeabi_set_attribute_int (Tag_ARM_ISA_use, 1); /* Tag_THUMB_ISA_use. */ - if (ARM_CPU_HAS_FEATURE (thumb_arch_used, arm_arch_full)) - bfd_elf_add_proc_attr_int (stdoutput, 9, - ARM_CPU_HAS_FEATURE (thumb_arch_used, arm_arch_t2) ? 2 : 1); + if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v4t) + || arch == 0) + aeabi_set_attribute_int (Tag_THUMB_ISA_use, + ARM_CPU_HAS_FEATURE (flags, arm_arch_t2) ? 2 : 1); /* Tag_VFP_arch. */ - if (ARM_CPU_HAS_FEATURE (thumb_arch_used, fpu_vfp_ext_d32) - || ARM_CPU_HAS_FEATURE (arm_arch_used, fpu_vfp_ext_d32)) - bfd_elf_add_proc_attr_int (stdoutput, 10, 4); - else if (ARM_CPU_HAS_FEATURE (thumb_arch_used, fpu_vfp_ext_v3) - || ARM_CPU_HAS_FEATURE (arm_arch_used, fpu_vfp_ext_v3)) - bfd_elf_add_proc_attr_int (stdoutput, 10, 3); - else if (ARM_CPU_HAS_FEATURE (thumb_arch_used, fpu_vfp_ext_v2) - || ARM_CPU_HAS_FEATURE (arm_arch_used, fpu_vfp_ext_v2)) - bfd_elf_add_proc_attr_int (stdoutput, 10, 2); - else if (ARM_CPU_HAS_FEATURE (thumb_arch_used, fpu_vfp_ext_v1) - || ARM_CPU_HAS_FEATURE (arm_arch_used, fpu_vfp_ext_v1) - || ARM_CPU_HAS_FEATURE (thumb_arch_used, fpu_vfp_ext_v1xd) - || ARM_CPU_HAS_FEATURE (arm_arch_used, fpu_vfp_ext_v1xd)) - bfd_elf_add_proc_attr_int (stdoutput, 10, 1); + if (ARM_CPU_HAS_FEATURE (flags, fpu_vfp_ext_d32)) + aeabi_set_attribute_int (Tag_VFP_arch, 3); + else if (ARM_CPU_HAS_FEATURE (flags, fpu_vfp_ext_v3)) + aeabi_set_attribute_int (Tag_VFP_arch, 4); + else if (ARM_CPU_HAS_FEATURE (flags, fpu_vfp_ext_v2)) + aeabi_set_attribute_int (Tag_VFP_arch, 2); + else if (ARM_CPU_HAS_FEATURE (flags, fpu_vfp_ext_v1) + || ARM_CPU_HAS_FEATURE (flags, fpu_vfp_ext_v1xd)) + aeabi_set_attribute_int (Tag_VFP_arch, 1); /* Tag_WMMX_arch. */ - if (ARM_CPU_HAS_FEATURE (thumb_arch_used, arm_cext_iwmmxt) - || ARM_CPU_HAS_FEATURE (arm_arch_used, arm_cext_iwmmxt)) - bfd_elf_add_proc_attr_int (stdoutput, 11, 1); - /* Tag_NEON_arch. */ + if (ARM_CPU_HAS_FEATURE (flags, arm_cext_iwmmxt2)) + aeabi_set_attribute_int (Tag_WMMX_arch, 2); + else if (ARM_CPU_HAS_FEATURE (flags, arm_cext_iwmmxt)) + aeabi_set_attribute_int (Tag_WMMX_arch, 1); + /* Tag_Advanced_SIMD_arch (formerly Tag_NEON_arch). */ if (ARM_CPU_HAS_FEATURE (flags, fpu_neon_ext_v1)) - bfd_elf_add_proc_attr_int (stdoutput, 12, 1); - /* Tag_NEON_FP16_arch. */ + aeabi_set_attribute_int (Tag_Advanced_SIMD_arch, 1); + /* Tag_VFP_HP_extension (formerly Tag_NEON_FP16_arch). */ if (ARM_CPU_HAS_FEATURE (flags, fpu_neon_fp16)) - bfd_elf_add_proc_attr_int (stdoutput, 36, 1); + aeabi_set_attribute_int (Tag_VFP_HP_extension, 1); } /* Add the default contents for the .ARM.attributes section. */ @@ -2060,8 +2060,9 @@ skip_past_char (char ** str, char c) } #define skip_past_comma(str) skip_past_char (str, ',') -/* Parse an attribute directive for VENDOR. */ -void +/* Parse an attribute directive for VENDOR. + Returns the attribute number read, or zero on error. */ +int s_vendor_attribute (int vendor) { expressionS exp; @@ -2104,7 +2105,7 @@ s_vendor_attribute (int vendor) { as_bad (_("Attribute name not recognised: %s"), name); ignore_rest_of_line (); - return; + return 0; } } @@ -2119,7 +2120,7 @@ s_vendor_attribute (int vendor) { as_bad (_("expected numeric constant")); ignore_rest_of_line (); - return; + return 0; } i = exp.X_add_number; } @@ -2128,7 +2129,7 @@ s_vendor_attribute (int vendor) { as_bad (_("expected comma")); ignore_rest_of_line (); - return; + return 0; } if (type & 2) { @@ -2156,14 +2157,15 @@ s_vendor_attribute (int vendor) } demand_empty_rest_of_line (); - return; + return tag; bad_string: as_bad (_("bad string constant")); ignore_rest_of_line (); - return; + return 0; bad: as_bad (_("expected <tag> , <value>")); ignore_rest_of_line (); + return 0; } /* Parse a .gnu_attribute directive. */ @@ -186,5 +186,5 @@ extern void stringer (int append_zero); extern void s_xstab (int what); extern void s_rva (int); extern void s_incbin (int); -extern void s_vendor_attribute (int); +extern int s_vendor_attribute (int); extern void s_weakref (int); diff --git a/gas/testsuite/ChangeLog b/gas/testsuite/ChangeLog index 2b1ddb0..a1ebfbd 100644 --- a/gas/testsuite/ChangeLog +++ b/gas/testsuite/ChangeLog @@ -1,3 +1,80 @@ +2009-01-26 Andrew Stubbs <ams@codesourcery.com> + + * gas/arm/attr-cpu-directive.d: New file. + * gas/arm/attr-cpu-directive.s: New file. + * gas/arm/attr-default.d: New file. + * gas/arm/attr-march-all.d: New file. + * gas/arm/attr-march-armv1.d: New file. + * gas/arm/attr-march-armv2.d: New file. + * gas/arm/attr-march-armv2a.d: New file. + * gas/arm/attr-march-armv2s.d: New file. + * gas/arm/attr-march-armv3.d: New file. + * gas/arm/attr-march-armv3m.d: New file. + * gas/arm/attr-march-armv4.d: New file. + * gas/arm/attr-march-armv4t.d: New file. + * gas/arm/attr-march-armv4txm.d: New file. + * gas/arm/attr-march-armv4xm.d: New file. + * gas/arm/attr-march-armv5.d: New file. + * gas/arm/attr-march-armv5t.d: New file. + * gas/arm/attr-march-armv5te.d: New file. + * gas/arm/attr-march-armv5tej.d: New file. + * gas/arm/attr-march-armv5texp.d: New file. + * gas/arm/attr-march-armv5txm.d: New file. + * gas/arm/attr-march-armv6-m.d: New file. + * gas/arm/attr-march-armv6.d: New file. + * gas/arm/attr-march-armv6j.d: New file. + * gas/arm/attr-march-armv6k.d: New file. + * gas/arm/attr-march-armv6kt2.d: New file. + * gas/arm/attr-march-armv6t2.d: New file. + * gas/arm/attr-march-armv6z.d: New file. + * gas/arm/attr-march-armv6zk.d: New file. + * gas/arm/attr-march-armv6zkt2.d: New file. + * gas/arm/attr-march-armv6zt2.d: New file. + * gas/arm/attr-march-armv7-a.d: New file. + * gas/arm/attr-march-armv7-m.d: New file. + * gas/arm/attr-march-armv7-r.d: New file. + * gas/arm/attr-march-armv7.d: New file. + * gas/arm/attr-march-armv7a.d: New file. + * gas/arm/attr-march-armv7m.d: New file. + * gas/arm/attr-march-armv7r.d: New file. + * gas/arm/attr-march-iwmmxt.d: New file. + * gas/arm/attr-march-iwmmxt2.d: New file. + * gas/arm/attr-march-xscale.d: New file. + * gas/arm/attr-mcpu.d: New file. + * gas/arm/attr-mfpu-arm1020e.d: New file. + * gas/arm/attr-mfpu-arm1020t.d: New file. + * gas/arm/attr-mfpu-arm1136jf-s.d: New file. + * gas/arm/attr-mfpu-arm1136jfs.d: New file. + * gas/arm/attr-mfpu-arm7500fe.d: New file. + * gas/arm/attr-mfpu-fpa.d: New file. + * gas/arm/attr-mfpu-fpa10.d: New file. + * gas/arm/attr-mfpu-fpa11.d: New file. + * gas/arm/attr-mfpu-fpe.d: New file. + * gas/arm/attr-mfpu-fpe2.d: New file. + * gas/arm/attr-mfpu-fpe3.d: New file. + * gas/arm/attr-mfpu-maverick.d: New file. + * gas/arm/attr-mfpu-neon-fp16.d: New file. + * gas/arm/attr-mfpu-neon.d: New file. + * gas/arm/attr-mfpu-softfpa.d: New file. + * gas/arm/attr-mfpu-softvfp+vfp.d: New file. + * gas/arm/attr-mfpu-softvfp.d: New file. + * gas/arm/attr-mfpu-vfp.d: New file. + * gas/arm/attr-mfpu-vfp10-r0.d: New file. + * gas/arm/attr-mfpu-vfp10.d: New file. + * gas/arm/attr-mfpu-vfp3.d: New file. + * gas/arm/attr-mfpu-vfp9.d: New file. + * gas/arm/attr-mfpu-vfpv2.d: New file. + * gas/arm/attr-mfpu-vfpv3-d16.d: New file. + * gas/arm/attr-mfpu-vfpv3.d: New file. + * gas/arm/attr-mfpu-vfpxd.d: New file. + * gas/arm/attr-order.d: Update Tag_ARM_ISA_use and Tag_THUMB_ISA_use. + * gas/arm/attr-override-cpu-directive.d: New file. + * gas/arm/attr-override-cpu-directive.s: New file. + * gas/arm/attr-override-mcpu.d: New file. + * gas/arm/attr-override-mcpu.s: New file. + * gas/arm/blank.s: New file. + * gas/arm/eabi_attr_1.d: Update Tag_ARM_ISA_use and Tag_THUMB_ISA_use. + 2009-01-26 Nick Clifton <nickc@redhat.com> * gas/arm/attr-order.d: Do not run this test for non-ELF based ARM diff --git a/gas/testsuite/gas/arm/attr-cpu-directive.d b/gas/testsuite/gas/arm/attr-cpu-directive.d new file mode 100644 index 0000000..357e804 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-cpu-directive.d @@ -0,0 +1,14 @@ +# name: EABI attributes from directives +# source: attr-cpu-directive.s +# as: +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "CORTEX-A8" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Application + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-cpu-directive.s b/gas/testsuite/gas/arm/attr-cpu-directive.s new file mode 100644 index 0000000..ced1ff4 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-cpu-directive.s @@ -0,0 +1 @@ + .cpu cortex-a8 diff --git a/gas/testsuite/gas/arm/attr-default.d b/gas/testsuite/gas/arm/attr-default.d new file mode 100644 index 0000000..fca3597 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-default.d @@ -0,0 +1,11 @@ +# name: EABI attribute defaults +# source: blank.s +# as: +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-all.d b/gas/testsuite/gas/arm/attr-march-all.d new file mode 100644 index 0000000..66f2f79 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-all.d @@ -0,0 +1,14 @@ +# name: attributes for -march=all +# source: blank.s +# as: -march=all +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "all" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Application + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv1.d b/gas/testsuite/gas/arm/attr-march-armv1.d new file mode 100644 index 0000000..d81b3e9 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv1.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv1 +# source: blank.s +# as: -march=armv1 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "1" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv2.d b/gas/testsuite/gas/arm/attr-march-armv2.d new file mode 100644 index 0000000..3c59db9 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv2.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv2 +# source: blank.s +# as: -march=armv2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "2" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv2a.d b/gas/testsuite/gas/arm/attr-march-armv2a.d new file mode 100644 index 0000000..1e6bcd0 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv2a.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv2a +# source: blank.s +# as: -march=armv2a +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "2A" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv2s.d b/gas/testsuite/gas/arm/attr-march-armv2s.d new file mode 100644 index 0000000..5dd6e89 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv2s.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv2s +# source: blank.s +# as: -march=armv2s +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "2S" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv3.d b/gas/testsuite/gas/arm/attr-march-armv3.d new file mode 100644 index 0000000..e34b83d --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv3.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv3 +# source: blank.s +# as: -march=armv3 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "3" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv3m.d b/gas/testsuite/gas/arm/attr-march-armv3m.d new file mode 100644 index 0000000..f911c70 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv3m.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv3m +# source: blank.s +# as: -march=armv3m +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "3M" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv4.d b/gas/testsuite/gas/arm/attr-march-armv4.d new file mode 100644 index 0000000..283cd70 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv4.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv4 +# source: blank.s +# as: -march=armv4 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "4" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv4t.d b/gas/testsuite/gas/arm/attr-march-armv4t.d new file mode 100644 index 0000000..fb860af --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv4t.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv4t +# source: blank.s +# as: -march=armv4t +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "4T" + Tag_CPU_arch: v4T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv4txm.d b/gas/testsuite/gas/arm/attr-march-armv4txm.d new file mode 100644 index 0000000..5995f29 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv4txm.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv4txm +# source: blank.s +# as: -march=armv4txm +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "4TXM" + Tag_CPU_arch: v4T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv4xm.d b/gas/testsuite/gas/arm/attr-march-armv4xm.d new file mode 100644 index 0000000..3ece898 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv4xm.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv4xm +# source: blank.s +# as: -march=armv4xm +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "4XM" + Tag_CPU_arch: v4 + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv5.d b/gas/testsuite/gas/arm/attr-march-armv5.d new file mode 100644 index 0000000..7ca0c76 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv5 +# source: blank.s +# as: -march=armv5 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5" + Tag_CPU_arch: v5T + Tag_ARM_ISA_use: Yes diff --git a/gas/testsuite/gas/arm/attr-march-armv5t.d b/gas/testsuite/gas/arm/attr-march-armv5t.d new file mode 100644 index 0000000..1d4d64d --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5t.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv5t +# source: blank.s +# as: -march=armv5t +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5T" + Tag_CPU_arch: v5T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv5te.d b/gas/testsuite/gas/arm/attr-march-armv5te.d new file mode 100644 index 0000000..311296d --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5te.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv5te +# source: blank.s +# as: -march=armv5te +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5TE" + Tag_CPU_arch: v5TE + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv5tej.d b/gas/testsuite/gas/arm/attr-march-armv5tej.d new file mode 100644 index 0000000..2ec8865 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5tej.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv5tej +# source: blank.s +# as: -march=armv5tej +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5TEJ" + Tag_CPU_arch: v5TEJ + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv5texp.d b/gas/testsuite/gas/arm/attr-march-armv5texp.d new file mode 100644 index 0000000..29fd3b3 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5texp.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv5texp +# source: blank.s +# as: -march=armv5texp +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5TEXP" + Tag_CPU_arch: v5TE + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv5txm.d b/gas/testsuite/gas/arm/attr-march-armv5txm.d new file mode 100644 index 0000000..c21a0ef --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv5txm.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv5txm +# source: blank.s +# as: -march=armv5txm +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "5TXM" + Tag_CPU_arch: v5T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6-m.d b/gas/testsuite/gas/arm/attr-march-armv6-m.d new file mode 100644 index 0000000..b5abfbd --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6-m.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6-m +# source: blank.s +# as: -march=armv6-m +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6-M" + Tag_CPU_arch: v6-M + Tag_CPU_arch_profile: Microcontroller + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6.d b/gas/testsuite/gas/arm/attr-march-armv6.d new file mode 100644 index 0000000..87afc90 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6 +# source: blank.s +# as: -march=armv6 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6" + Tag_CPU_arch: v6 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6j.d b/gas/testsuite/gas/arm/attr-march-armv6j.d new file mode 100644 index 0000000..2d9ec70 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6j.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6j +# source: blank.s +# as: -march=armv6j +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6J" + Tag_CPU_arch: v6 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6k.d b/gas/testsuite/gas/arm/attr-march-armv6k.d new file mode 100644 index 0000000..2bb0ba8 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6k.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6k +# source: blank.s +# as: -march=armv6k +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6K" + Tag_CPU_arch: v6K + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6kt2.d b/gas/testsuite/gas/arm/attr-march-armv6kt2.d new file mode 100644 index 0000000..305040f --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6kt2.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6kt2 +# source: blank.s +# as: -march=armv6kt2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6KT2" + Tag_CPU_arch: v6T2 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv6t2.d b/gas/testsuite/gas/arm/attr-march-armv6t2.d new file mode 100644 index 0000000..641ed9c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6t2.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6t2 +# source: blank.s +# as: -march=armv6t2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6T2" + Tag_CPU_arch: v6T2 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv6z.d b/gas/testsuite/gas/arm/attr-march-armv6z.d new file mode 100644 index 0000000..9870462 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6z.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6z +# source: blank.s +# as: -march=armv6z +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6Z" + Tag_CPU_arch: v6KZ + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6zk.d b/gas/testsuite/gas/arm/attr-march-armv6zk.d new file mode 100644 index 0000000..bec40e5 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6zk.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6zk +# source: blank.s +# as: -march=armv6zk +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6ZK" + Tag_CPU_arch: v6K + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-march-armv6zkt2.d b/gas/testsuite/gas/arm/attr-march-armv6zkt2.d new file mode 100644 index 0000000..672acd8 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6zkt2.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6zkt2 +# source: blank.s +# as: -march=armv6zkt2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6ZKT2" + Tag_CPU_arch: v6T2 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv6zt2.d b/gas/testsuite/gas/arm/attr-march-armv6zt2.d new file mode 100644 index 0000000..e88d7eb --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv6zt2.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv6zt2 +# source: blank.s +# as: -march=armv6zt2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "6ZT2" + Tag_CPU_arch: v6T2 + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7-a.d b/gas/testsuite/gas/arm/attr-march-armv7-a.d new file mode 100644 index 0000000..6074a10 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7-a.d @@ -0,0 +1,14 @@ +# name: attributes for -march=armv7-a +# source: blank.s +# as: -march=armv7-a +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7-A" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Application + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7-m.d b/gas/testsuite/gas/arm/attr-march-armv7-m.d new file mode 100644 index 0000000..e768201 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7-m.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv7-m +# source: blank.s +# as: -march=armv7-m +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7-M" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Microcontroller + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7-r.d b/gas/testsuite/gas/arm/attr-march-armv7-r.d new file mode 100644 index 0000000..3bfeb2b --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7-r.d @@ -0,0 +1,14 @@ +# name: attributes for -march=armv7-r +# source: blank.s +# as: -march=armv7-r +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7-R" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Realtime + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7.d b/gas/testsuite/gas/arm/attr-march-armv7.d new file mode 100644 index 0000000..ffb3dc1 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7.d @@ -0,0 +1,12 @@ +# name: attributes for -march=armv7 +# source: blank.s +# as: -march=armv7 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7" + Tag_CPU_arch: v7 + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7a.d b/gas/testsuite/gas/arm/attr-march-armv7a.d new file mode 100644 index 0000000..053c99f --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7a.d @@ -0,0 +1,14 @@ +# name: attributes for -march=armv7a +# source: blank.s +# as: -march=armv7a +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7A" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Application + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7m.d b/gas/testsuite/gas/arm/attr-march-armv7m.d new file mode 100644 index 0000000..ae0a767 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7m.d @@ -0,0 +1,13 @@ +# name: attributes for -march=armv7m +# source: blank.s +# as: -march=armv7m +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7M" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Microcontroller + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-armv7r.d b/gas/testsuite/gas/arm/attr-march-armv7r.d new file mode 100644 index 0000000..b7aa094 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-armv7r.d @@ -0,0 +1,14 @@ +# name: attributes for -march=armv7r +# source: blank.s +# as: -march=armv7r +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "7R" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Realtime + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 diff --git a/gas/testsuite/gas/arm/attr-march-iwmmxt.d b/gas/testsuite/gas/arm/attr-march-iwmmxt.d new file mode 100644 index 0000000..1d0358b --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-iwmmxt.d @@ -0,0 +1,14 @@ +# name: attributes for -march=iwmmxt +# source: blank.s +# as: -march=iwmmxt +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "iwmmxt" + Tag_CPU_arch: v5TE + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_WMMX_arch: WMMXv1 diff --git a/gas/testsuite/gas/arm/attr-march-iwmmxt2.d b/gas/testsuite/gas/arm/attr-march-iwmmxt2.d new file mode 100644 index 0000000..28b799a --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-iwmmxt2.d @@ -0,0 +1,14 @@ +# name: attributes for -march=iwmmxt2 +# source: blank.s +# as: -march=iwmmxt2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "iwmmxt2" + Tag_CPU_arch: v5TE + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_WMMX_arch: WMMXv2 diff --git a/gas/testsuite/gas/arm/attr-march-xscale.d b/gas/testsuite/gas/arm/attr-march-xscale.d new file mode 100644 index 0000000..b723f50 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-march-xscale.d @@ -0,0 +1,13 @@ +# name: attributes for -march=xscale +# source: blank.s +# as: -march=xscale +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "xscale" + Tag_CPU_arch: v5TE + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mcpu.d b/gas/testsuite/gas/arm/attr-mcpu.d new file mode 100644 index 0000000..1a1c07f --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mcpu.d @@ -0,0 +1,16 @@ +# name: EABI attributes from command line +# source: blank.s +# as: -mcpu=cortex-a8 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "CORTEX-A8" + Tag_CPU_arch: v7 + Tag_CPU_arch_profile: Application + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-2 + Tag_VFP_arch: VFPv3 + Tag_Advanced_SIMD_arch: NEONv1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-arm1020e.d b/gas/testsuite/gas/arm/attr-mfpu-arm1020e.d new file mode 100644 index 0000000..bbdd244 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-arm1020e.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=arm1020e +# source: blank.s +# as: -mfpu=arm1020e +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-arm1020t.d b/gas/testsuite/gas/arm/attr-mfpu-arm1020t.d new file mode 100644 index 0000000..5a5e413 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-arm1020t.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=arm1020t +# source: blank.s +# as: -mfpu=arm1020t +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-arm1136jf-s.d b/gas/testsuite/gas/arm/attr-mfpu-arm1136jf-s.d new file mode 100644 index 0000000..1523c29 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-arm1136jf-s.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=arm1136jf-s +# source: blank.s +# as: -mfpu=arm1136jf-s +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-arm1136jfs.d b/gas/testsuite/gas/arm/attr-mfpu-arm1136jfs.d new file mode 100644 index 0000000..745a913 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-arm1136jfs.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=arm1136jfs +# source: blank.s +# as: -mfpu=arm1136jfs +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-arm7500fe.d b/gas/testsuite/gas/arm/attr-mfpu-arm7500fe.d new file mode 100644 index 0000000..8f789e2 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-arm7500fe.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=arm7500fe +# source: blank.s +# as: -mfpu=arm7500fe +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpa.d b/gas/testsuite/gas/arm/attr-mfpu-fpa.d new file mode 100644 index 0000000..196a0d0 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpa.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpa +# source: blank.s +# as: -mfpu=fpa +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpa10.d b/gas/testsuite/gas/arm/attr-mfpu-fpa10.d new file mode 100644 index 0000000..23373b6 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpa10.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpa10 +# source: blank.s +# as: -mfpu=fpa10 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpa11.d b/gas/testsuite/gas/arm/attr-mfpu-fpa11.d new file mode 100644 index 0000000..c8928dd --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpa11.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpa11 +# source: blank.s +# as: -mfpu=fpa11 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpe.d b/gas/testsuite/gas/arm/attr-mfpu-fpe.d new file mode 100644 index 0000000..a4b485a --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpe.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpe +# source: blank.s +# as: -mfpu=fpe +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpe2.d b/gas/testsuite/gas/arm/attr-mfpu-fpe2.d new file mode 100644 index 0000000..e848056 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpe2.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpe2 +# source: blank.s +# as: -mfpu=fpe2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-fpe3.d b/gas/testsuite/gas/arm/attr-mfpu-fpe3.d new file mode 100644 index 0000000..108625c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-fpe3.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=fpe3 +# source: blank.s +# as: -mfpu=fpe3 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-maverick.d b/gas/testsuite/gas/arm/attr-mfpu-maverick.d new file mode 100644 index 0000000..9ea4854 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-maverick.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=maverick +# source: blank.s +# as: -mfpu=maverick +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-neon-fp16.d b/gas/testsuite/gas/arm/attr-mfpu-neon-fp16.d new file mode 100644 index 0000000..818982d --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-neon-fp16.d @@ -0,0 +1,14 @@ +# name: attributes for -mfpu=neon-fp16 +# source: blank.s +# as: -mfpu=neon-fp16 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv3 + Tag_Advanced_SIMD_arch: NEONv1 + Tag_VFP_HP_extension: Allowed diff --git a/gas/testsuite/gas/arm/attr-mfpu-neon.d b/gas/testsuite/gas/arm/attr-mfpu-neon.d new file mode 100644 index 0000000..1480962 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-neon.d @@ -0,0 +1,13 @@ +# name: attributes for -mfpu=neon +# source: blank.s +# as: -mfpu=neon +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv3 + Tag_Advanced_SIMD_arch: NEONv1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-softfpa.d b/gas/testsuite/gas/arm/attr-mfpu-softfpa.d new file mode 100644 index 0000000..5a0fa17 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-softfpa.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=softfpa +# source: blank.s +# as: -mfpu=softfpa +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-softvfp+vfp.d b/gas/testsuite/gas/arm/attr-mfpu-softvfp+vfp.d new file mode 100644 index 0000000..7b21310 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-softvfp+vfp.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=softvfp+vfp +# source: blank.s +# as: -mfpu=softvfp+vfp +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-softvfp.d b/gas/testsuite/gas/arm/attr-mfpu-softvfp.d new file mode 100644 index 0000000..c44dda5 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-softvfp.d @@ -0,0 +1,11 @@ +# name: attributes for -mfpu=softvfp +# source: blank.s +# as: -mfpu=softvfp +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfp.d b/gas/testsuite/gas/arm/attr-mfpu-vfp.d new file mode 100644 index 0000000..49ae2b3 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfp.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfp +# source: blank.s +# as: -mfpu=vfp +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfp10-r0.d b/gas/testsuite/gas/arm/attr-mfpu-vfp10-r0.d new file mode 100644 index 0000000..1f6cb2b --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfp10-r0.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfp10-r0 +# source: blank.s +# as: -mfpu=vfp10-r0 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv1 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfp10.d b/gas/testsuite/gas/arm/attr-mfpu-vfp10.d new file mode 100644 index 0000000..e72bcfa --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfp10.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfp10 +# source: blank.s +# as: -mfpu=vfp10 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfp3.d b/gas/testsuite/gas/arm/attr-mfpu-vfp3.d new file mode 100644 index 0000000..8512e9d --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfp3.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfp3 +# source: blank.s +# as: -mfpu=vfp3 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv3 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfp9.d b/gas/testsuite/gas/arm/attr-mfpu-vfp9.d new file mode 100644 index 0000000..35f53bb --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfp9.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfp9 +# source: blank.s +# as: -mfpu=vfp9 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfpv2.d b/gas/testsuite/gas/arm/attr-mfpu-vfpv2.d new file mode 100644 index 0000000..4091e4c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfpv2.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfpv2 +# source: blank.s +# as: -mfpu=vfpv2 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv2 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfpv3-d16.d b/gas/testsuite/gas/arm/attr-mfpu-vfpv3-d16.d new file mode 100644 index 0000000..5542ee6 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfpv3-d16.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfpv3-d16 +# source: blank.s +# as: -mfpu=vfpv3-d16 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv3-D16 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfpv3.d b/gas/testsuite/gas/arm/attr-mfpu-vfpv3.d new file mode 100644 index 0000000..a5e4b7e --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfpv3.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfpv3 +# source: blank.s +# as: -mfpu=vfpv3 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv3 diff --git a/gas/testsuite/gas/arm/attr-mfpu-vfpxd.d b/gas/testsuite/gas/arm/attr-mfpu-vfpxd.d new file mode 100644 index 0000000..6c1154c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-mfpu-vfpxd.d @@ -0,0 +1,12 @@ +# name: attributes for -mfpu=vfpxd +# source: blank.s +# as: -mfpu=vfpxd +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 + Tag_VFP_arch: VFPv1 diff --git a/gas/testsuite/gas/arm/attr-order.d b/gas/testsuite/gas/arm/attr-order.d index eee7153..2d58ec4 100644 --- a/gas/testsuite/gas/arm/attr-order.d +++ b/gas/testsuite/gas/arm/attr-order.d @@ -11,6 +11,8 @@ File Attributes Tag_nodefaults: True Tag_CPU_name: "ARM7TDMI" Tag_CPU_arch: v4T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 Tag_unknown_63: "val" Tag_also_compatible_with: v6-M Tag_T2EE_use: Allowed diff --git a/gas/testsuite/gas/arm/attr-override-cpu-directive.d b/gas/testsuite/gas/arm/attr-override-cpu-directive.d new file mode 100644 index 0000000..c8e0831 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-override-cpu-directive.d @@ -0,0 +1,12 @@ +# name: EABI attributes .eabi_attribute overrides .cpu +# source: attr-override-cpu-directive.s +# as: +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "custom name" + Tag_CPU_arch: v7 + Tag_THUMB_ISA_use: \?\?\? \(10\) diff --git a/gas/testsuite/gas/arm/attr-override-cpu-directive.s b/gas/testsuite/gas/arm/attr-override-cpu-directive.s new file mode 100644 index 0000000..21a2812 --- /dev/null +++ b/gas/testsuite/gas/arm/attr-override-cpu-directive.s @@ -0,0 +1,5 @@ + .cpu arm7tdmi + .eabi_attribute Tag_CPU_name, "custom name" + .eabi_attribute Tag_CPU_arch, 10 + .eabi_attribute Tag_ARM_ISA_use, 0 + .eabi_attribute Tag_THUMB_ISA_use, 10 diff --git a/gas/testsuite/gas/arm/attr-override-mcpu.d b/gas/testsuite/gas/arm/attr-override-mcpu.d new file mode 100644 index 0000000..31da04c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-override-mcpu.d @@ -0,0 +1,13 @@ +# name: EABI attributes .cpu overrides -mcpu +# source: attr-override-mcpu.s +# as: -mcpu=cortex-a8 +# readelf: -A +# This test is only valid on ELF based ports. +# not-target: *-*-*coff *-*-pe *-*-wince *-*-*aout* *-*-netbsd *-*-riscix* + +Attribute Section: aeabi +File Attributes + Tag_CPU_name: "ARM7TDMI" + Tag_CPU_arch: v4T + Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 diff --git a/gas/testsuite/gas/arm/attr-override-mcpu.s b/gas/testsuite/gas/arm/attr-override-mcpu.s new file mode 100644 index 0000000..bc7a04c --- /dev/null +++ b/gas/testsuite/gas/arm/attr-override-mcpu.s @@ -0,0 +1,2 @@ + .cpu arm7tdmi + .fpu softfpa diff --git a/gas/testsuite/gas/arm/blank.s b/gas/testsuite/gas/arm/blank.s new file mode 100644 index 0000000..1d22054 --- /dev/null +++ b/gas/testsuite/gas/arm/blank.s @@ -0,0 +1 @@ +@ this file left intentionally blank diff --git a/gas/testsuite/gas/arm/eabi_attr_1.d b/gas/testsuite/gas/arm/eabi_attr_1.d index 0e97add..e3e3982 100644 --- a/gas/testsuite/gas/arm/eabi_attr_1.d +++ b/gas/testsuite/gas/arm/eabi_attr_1.d @@ -7,6 +7,7 @@ File Attributes Tag_CPU_name: "ARM1136JF-S" Tag_CPU_arch: v6 Tag_ARM_ISA_use: Yes + Tag_THUMB_ISA_use: Thumb-1 Tag_ABI_VFP_args: VFP registers Tag_compatibility: flag = 3, vendor = GNU Tag_unknown_128: 1234 \(0x4d2\) |