mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-19 00:59:15 +08:00
[Patch ARM] Fix build attributes for armv8-a in case of assembler files that contain no directives.
There is currently a problem in the way in which we produce build attributes for simple assembler files that have armv8-a instructions. In these case we need to generate TAG_ISA_THUMB_Use to be Thumb-2 and set the architecture profile to be 'A' rather than not setting architecture profile to be 'A' and setting TAG_ISA_THUMB_Use to be Thumb-1. This is a pre-requisite for any v8-m patches that have been posted. arm-none-eabi gas testsuite run. no regressions. 2015-12-17 Ramana Radhakrishnan <ramana.radhakrishnan@arm.com> * gas/config/tc-arm.c (aeabi_set_public_attributes): Adjust TAG_ARCH_profile for armv8-a. * gas/testsuite/gas/arm/armv8a-automatic-hlt.d: New test. * gas/testsuite/gas/arm/armv8a-automatic-hlt.s: New test. * gas/testsuite/gas/arm/armv8a-automatic-lda.d: New test. * gas/testsuite/gas/arm/armv8a-automatic-lda.s: New test.
This commit is contained in:
@ -25649,7 +25649,8 @@ aeabi_set_public_attributes (void)
|
|||||||
aeabi_set_attribute_int (Tag_CPU_arch, arch);
|
aeabi_set_attribute_int (Tag_CPU_arch, arch);
|
||||||
|
|
||||||
/* Tag_CPU_arch_profile. */
|
/* Tag_CPU_arch_profile. */
|
||||||
if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7a))
|
if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7a)
|
||||||
|
|| ARM_CPU_HAS_FEATURE (flags, arm_ext_v8))
|
||||||
profile = 'A';
|
profile = 'A';
|
||||||
else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7r))
|
else if (ARM_CPU_HAS_FEATURE (flags, arm_ext_v7r))
|
||||||
profile = 'R';
|
profile = 'R';
|
||||||
|
8
gas/testsuite/gas/arm/armv8a-automatic-hlt.d
Normal file
8
gas/testsuite/gas/arm/armv8a-automatic-hlt.d
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# 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_arch: v8
|
||||||
|
Tag_CPU_arch_profile: Application
|
||||||
|
Tag_THUMB_ISA_use: Thumb-2
|
6
gas/testsuite/gas/arm/armv8a-automatic-hlt.s
Normal file
6
gas/testsuite/gas/arm/armv8a-automatic-hlt.s
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
.thumb
|
||||||
|
.syntax unified
|
||||||
|
hlt
|
||||||
|
stlexd r0, r2, [r3]
|
||||||
|
sevl
|
||||||
|
hlt 0xf
|
8
gas/testsuite/gas/arm/armv8a-automatic-lda.d
Normal file
8
gas/testsuite/gas/arm/armv8a-automatic-lda.d
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# 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_arch: v8
|
||||||
|
Tag_CPU_arch_profile: Application
|
||||||
|
Tag_THUMB_ISA_use: Thumb-2
|
4
gas/testsuite/gas/arm/armv8a-automatic-lda.s
Normal file
4
gas/testsuite/gas/arm/armv8a-automatic-lda.s
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
.thumb
|
||||||
|
.syntax unified
|
||||||
|
lda r0, [r0]
|
||||||
|
stl r0, [r1]
|
@ -265,7 +265,8 @@
|
|||||||
#define FPU_ANY_HARD ARM_FEATURE_COPROC (FPU_FPA | FPU_VFP_HARD | FPU_MAVERICK)
|
#define FPU_ANY_HARD ARM_FEATURE_COPROC (FPU_FPA | FPU_VFP_HARD | FPU_MAVERICK)
|
||||||
#define ARM_ARCH_THUMB2 ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2 | ARM_EXT_V7 \
|
#define ARM_ARCH_THUMB2 ARM_FEATURE_CORE_LOW (ARM_EXT_V6T2 | ARM_EXT_V7 \
|
||||||
| ARM_EXT_V7A | ARM_EXT_V7R \
|
| ARM_EXT_V7A | ARM_EXT_V7R \
|
||||||
| ARM_EXT_V7M | ARM_EXT_DIV)
|
| ARM_EXT_V7M | ARM_EXT_DIV \
|
||||||
|
| ARM_EXT_V8)
|
||||||
/* v7-a+sec. */
|
/* v7-a+sec. */
|
||||||
#define ARM_ARCH_V7A_SEC ARM_FEATURE_CORE_LOW (ARM_AEXT_V7A | ARM_EXT_SEC)
|
#define ARM_ARCH_V7A_SEC ARM_FEATURE_CORE_LOW (ARM_AEXT_V7A | ARM_EXT_SEC)
|
||||||
/* v7-a+mp+sec. */
|
/* v7-a+mp+sec. */
|
||||||
|
Reference in New Issue
Block a user