2014-11-03 14:52:00 +00:00
|
|
|
@ RUN: llvm-mc -triple armv7-elf -filetype asm -o - %s | FileCheck %s
|
[arm] Implement eabi_attribute, cpu, and fpu directives.
This commit allows the ARM integrated assembler to parse
and assemble the code with .eabi_attribute, .cpu, and
.fpu directives.
To implement the feature, this commit moves the code from
AttrEmitter to ARMTargetStreamers, and several new test
cases related to cortex-m4, cortex-r5, and cortex-a15 are
added.
Besides, this commit also change the Subtarget->isFPOnlySP()
to Subtarget->hasD16() to match the usage of .fpu directive.
This commit changes the test cases:
* Several .eabi_attribute directives in
2010-09-29-mc-asm-header-test.ll are removed because the .fpu
directive already cover the functionality.
* In the Cortex-A15 test case, the value for
Tag_Advanced_SIMD_arch has be changed from 1 to 2,
which is more precise.
llvm-svn: 193524
2013-10-28 17:51:12 +00:00
|
|
|
@ RUN: llvm-mc < %s -triple armv7-unknown-linux-gnueabi -filetype=obj -o - \
|
2014-11-03 14:52:00 +00:00
|
|
|
@ RUN: | llvm-readobj -arm-attributes | FileCheck %s --check-prefix=CHECK-OBJ
|
[arm] Implement eabi_attribute, cpu, and fpu directives.
This commit allows the ARM integrated assembler to parse
and assemble the code with .eabi_attribute, .cpu, and
.fpu directives.
To implement the feature, this commit moves the code from
AttrEmitter to ARMTargetStreamers, and several new test
cases related to cortex-m4, cortex-r5, and cortex-a15 are
added.
Besides, this commit also change the Subtarget->isFPOnlySP()
to Subtarget->hasD16() to match the usage of .fpu directive.
This commit changes the test cases:
* Several .eabi_attribute directives in
2010-09-29-mc-asm-header-test.ll are removed because the .fpu
directive already cover the functionality.
* In the Cortex-A15 test case, the value for
Tag_Advanced_SIMD_arch has be changed from 1 to 2,
which is more precise.
llvm-svn: 193524
2013-10-28 17:51:12 +00:00
|
|
|
|
2014-11-04 09:07:40 +00:00
|
|
|
.syntax unified
|
|
|
|
.thumb
|
2014-11-03 14:52:00 +00:00
|
|
|
|
2015-01-05 13:12:17 +00:00
|
|
|
.eabi_attribute Tag_conformance, "2.09"
|
|
|
|
@ CHECK: .eabi_attribute 67, "2.09"
|
|
|
|
@ Tag_conformance should be be emitted first in a file-scope
|
|
|
|
@ sub-subsection of the first public subsection of the attributes
|
|
|
|
@ section. 2.3.7.4 of ABI Addenda.
|
|
|
|
@ CHECK-OBJ: Tag: 67
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: conformance
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 2.09
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_CPU_raw_name, "Cortex-A9"
|
|
|
|
@ CHECK: .eabi_attribute 4, "Cortex-A9"
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 4
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: CPU_raw_name
|
2014-11-27 12:13:56 +00:00
|
|
|
@ CHECK-OBJ-NEXT: Value: Cortex-A9
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_CPU_name, "cortex-a9"
|
|
|
|
@ CHECK: .cpu cortex-a9
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 5
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: CPU_name
|
2014-11-27 12:13:56 +00:00
|
|
|
@ CHECK-OBJ-NEXT: Value: cortex-a9
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_CPU_arch, 10
|
|
|
|
@ CHECK: .eabi_attribute 6, 10
|
|
|
|
@ CHECK-OBJ: Tag: 6
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 10
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: CPU_arch
|
|
|
|
@ CHECK-OBJ-NEXT: Description: ARM v7
|
|
|
|
.eabi_attribute Tag_CPU_arch_profile, 'A'
|
|
|
|
@ CHECK: .eabi_attribute 7, 65
|
|
|
|
@ CHECK-OBJ: Tag: 7
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 65
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: CPU_arch_profile
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Application
|
|
|
|
.eabi_attribute Tag_ARM_ISA_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 8, 0
|
|
|
|
@ CHECK-OBJ: Tag: 8
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ARM_ISA_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
|
|
|
.eabi_attribute Tag_THUMB_ISA_use, 2
|
|
|
|
@ CHECK: .eabi_attribute 9, 2
|
|
|
|
@ CHECK-OBJ: Tag: 9
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 2
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: THUMB_ISA_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Thumb-2
|
|
|
|
.eabi_attribute Tag_FP_arch, 3
|
|
|
|
@ CHECK: .eabi_attribute 10, 3
|
|
|
|
@ CHECK-OBJ: Tag: 10
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 3
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: FP_arch
|
|
|
|
@ CHECK-OBJ-NEXT: Description: VFPv3
|
|
|
|
.eabi_attribute Tag_WMMX_arch, 0
|
|
|
|
@ CHECK: .eabi_attribute 11, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 11
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: WMMX_arch
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_Advanced_SIMD_arch, 1
|
|
|
|
@ CHECK: .eabi_attribute 12, 1
|
|
|
|
@ CHECK-OBJ: Tag: 12
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: Advanced_SIMD_arch
|
|
|
|
@ CHECK-OBJ-NEXT: Description: NEONv1
|
|
|
|
.eabi_attribute Tag_PCS_config, 2
|
|
|
|
@ CHECK: .eabi_attribute 13, 2
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 13
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 2
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: PCS_config
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Linux Application
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_PCS_R9_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 14, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 14
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_PCS_R9_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: v6
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_PCS_RW_data, 0
|
|
|
|
@ CHECK: .eabi_attribute 15, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 15
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_PCS_RW_data
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Absolute
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_PCS_RO_data, 0
|
|
|
|
@ CHECK: .eabi_attribute 16, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 16
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_PCS_RO_data
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Absolute
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_PCS_GOT_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 17, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 17
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_PCS_GOT_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_PCS_wchar_t, 4
|
|
|
|
@ CHECK: .eabi_attribute 18, 4
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 18
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 4
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_PCS_wchar_t
|
|
|
|
@ CHECK-OBJ-NEXT: Description: 4-byte
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_FP_rounding, 1
|
|
|
|
@ CHECK: .eabi_attribute 19, 1
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 19
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_rounding
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Runtime
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_FP_denormal, 2
|
|
|
|
@ CHECK: .eabi_attribute 20, 2
|
|
|
|
@ CHECK-OBJ: Tag: 20
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 2
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_denormal
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Sign Only
|
|
|
|
.eabi_attribute Tag_ABI_FP_exceptions, 1
|
|
|
|
@ CHECK: .eabi_attribute 21, 1
|
|
|
|
@ CHECK-OBJ: Tag: 21
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_exceptions
|
|
|
|
@ CHECK-OBJ-NEXT: Description: IEEE-754
|
|
|
|
.eabi_attribute Tag_ABI_FP_user_exceptions, 1
|
|
|
|
@ CHECK: .eabi_attribute 22, 1
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 22
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_user_exceptions
|
|
|
|
@ CHECK-OBJ-NEXT: Description: IEEE-754
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_FP_number_model, 3
|
|
|
|
@ CHECK: .eabi_attribute 23, 3
|
|
|
|
@ CHECK-OBJ: Tag: 23
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 3
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_number_model
|
|
|
|
@ CHECK-OBJ-NEXT: Description: IEEE-754
|
|
|
|
.eabi_attribute Tag_ABI_align_needed, 1
|
|
|
|
@ CHECK: .eabi_attribute 24, 1
|
|
|
|
@ CHECK-OBJ: Tag: 24
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_align_needed
|
|
|
|
@ CHECK-OBJ-NEXT: Description: 8-byte alignment
|
|
|
|
.eabi_attribute Tag_ABI_align_preserved, 2
|
|
|
|
@ CHECK: .eabi_attribute 25, 2
|
|
|
|
@ CHECK-OBJ: Tag: 25
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 2
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_align_preserved
|
|
|
|
@ CHECK-OBJ-NEXT: Description: 8-byte data and code alignment
|
|
|
|
.eabi_attribute Tag_ABI_enum_size, 3
|
|
|
|
@ CHECK: .eabi_attribute 26, 3
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 26
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 3
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_enum_size
|
|
|
|
@ CHECK-OBJ-NEXT: Description: External Int32
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_HardFP_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 27, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 27
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_HardFP_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Tag_FP_arch
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_VFP_args, 1
|
|
|
|
@ CHECK: .eabi_attribute 28, 1
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 28
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_VFP_args
|
|
|
|
@ CHECK-OBJ-NEXT: Description: AAPCS VFP
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_WMMX_args, 0
|
|
|
|
@ CHECK: .eabi_attribute 29, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 29
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_WMMX_args
|
|
|
|
@ CHECK-OBJ-NEXT: Description: AAPCS
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_FP_optimization_goals, 1
|
|
|
|
@ CHECK: .eabi_attribute 31, 1
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 31
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 1
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_optimization_goals
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Speed
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_compatibility, 1, "aeabi"
|
|
|
|
@ CHECK: .eabi_attribute 32, 1, "aeabi"
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 32
|
2014-11-27 12:13:56 +00:00
|
|
|
@ CHECK-OBJ-NEXT: Value: 1, aeabi
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ-NEXT: TagName: compatibility
|
|
|
|
@ CHECK-OBJ-NEXT: Description: AEABI Conformant
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_CPU_unaligned_access, 0
|
|
|
|
@ CHECK: .eabi_attribute 34, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 34
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: CPU_unaligned_access
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_FP_HP_extension, 0
|
|
|
|
@ CHECK: .eabi_attribute 36, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 36
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: FP_HP_extension
|
|
|
|
@ CHECK-OBJ-NEXT: Description: If Available
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_ABI_FP_16bit_format, 0
|
|
|
|
@ CHECK: .eabi_attribute 38, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 38
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: ABI_FP_16bit_format
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitte
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_MPextension_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 42, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 42
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: MPextension_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_DIV_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 44, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 44
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: DIV_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: If Available
|
2016-01-25 11:26:11 +00:00
|
|
|
.eabi_attribute Tag_DSP_extension, 0
|
|
|
|
@ CHECK: .eabi_attribute 46, 0
|
|
|
|
@ CHECK-OBJ: Tag: 46
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: DSP_extension
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_nodefaults, 0
|
|
|
|
@ CHECK: .eabi_attribute 64, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 64
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: nodefaults
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Unspecified Tags UNDEFINED
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_also_compatible_with, "gnu"
|
|
|
|
@ CHECK: .eabi_attribute 65, "gnu"
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 65
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: also_compatible_with
|
2014-11-27 12:13:56 +00:00
|
|
|
@ CHECK-OBJ-NEXT: Value: gnu
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_T2EE_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 66, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 66
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: T2EE_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
.eabi_attribute Tag_Virtualization_use, 0
|
|
|
|
@ CHECK: .eabi_attribute 68, 0
|
2014-11-04 09:07:40 +00:00
|
|
|
@ CHECK-OBJ: Tag: 68
|
|
|
|
@ CHECK-OBJ-NEXT: Value: 0
|
|
|
|
@ CHECK-OBJ-NEXT: TagName: Virtualization_use
|
|
|
|
@ CHECK-OBJ-NEXT: Description: Not Permitted
|
2014-11-03 14:52:00 +00:00
|
|
|
|
|
|
|
@ ===--- Compatibility Checks ---===
|
|
|
|
|
|
|
|
.eabi_attribute Tag_ABI_align8_needed, 1
|
|
|
|
@ CHECK: .eabi_attribute 24, 1
|
|
|
|
.eabi_attribute Tag_ABI_align8_preserved, 2
|
|
|
|
@ CHECK: .eabi_attribute 25, 2
|
|
|
|
|
|
|
|
@ ===--- GNU AS Compatibility Checks ---===
|
|
|
|
|
|
|
|
.eabi_attribute 2 * 2 + 1, "cortex-a9"
|
|
|
|
@ CHECK: .cpu cortex-a9
|
|
|
|
.eabi_attribute 2 * 2 + 2, 5 * 2
|
|
|
|
@ CHECK: .eabi_attribute 6, 10
|