1*9880d681SAndroid Build Coastguard Worker //===-- ARMBuildAttrs.cpp - ARM Build Attributes --------------------------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/ARMBuildAttributes.h"
11*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/StringRef.h"
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Worker using namespace llvm;
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Worker namespace {
16*9880d681SAndroid Build Coastguard Worker const struct {
17*9880d681SAndroid Build Coastguard Worker ARMBuildAttrs::AttrType Attr;
18*9880d681SAndroid Build Coastguard Worker const char *TagName;
19*9880d681SAndroid Build Coastguard Worker } ARMAttributeTags[] = {
20*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::File, "Tag_File" },
21*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::Section, "Tag_Section" },
22*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::Symbol, "Tag_Symbol" },
23*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::CPU_raw_name, "Tag_CPU_raw_name" },
24*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::CPU_name, "Tag_CPU_name" },
25*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::CPU_arch, "Tag_CPU_arch" },
26*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::CPU_arch_profile, "Tag_CPU_arch_profile" },
27*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ARM_ISA_use, "Tag_ARM_ISA_use" },
28*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::THUMB_ISA_use, "Tag_THUMB_ISA_use" },
29*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::FP_arch, "Tag_FP_arch" },
30*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::WMMX_arch, "Tag_WMMX_arch" },
31*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::Advanced_SIMD_arch, "Tag_Advanced_SIMD_arch" },
32*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::PCS_config, "Tag_PCS_config" },
33*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_PCS_R9_use, "Tag_ABI_PCS_R9_use" },
34*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_PCS_RW_data, "Tag_ABI_PCS_RW_data" },
35*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_PCS_RO_data, "Tag_ABI_PCS_RO_data" },
36*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_PCS_GOT_use, "Tag_ABI_PCS_GOT_use" },
37*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_PCS_wchar_t, "Tag_ABI_PCS_wchar_t" },
38*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_rounding, "Tag_ABI_FP_rounding" },
39*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_denormal, "Tag_ABI_FP_denormal" },
40*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_exceptions, "Tag_ABI_FP_exceptions" },
41*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_user_exceptions, "Tag_ABI_FP_user_exceptions" },
42*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_number_model, "Tag_ABI_FP_number_model" },
43*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_align_needed, "Tag_ABI_align_needed" },
44*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_align_preserved, "Tag_ABI_align_preserved" },
45*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_enum_size, "Tag_ABI_enum_size" },
46*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_HardFP_use, "Tag_ABI_HardFP_use" },
47*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_VFP_args, "Tag_ABI_VFP_args" },
48*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_WMMX_args, "Tag_ABI_WMMX_args" },
49*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_optimization_goals, "Tag_ABI_optimization_goals" },
50*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_optimization_goals, "Tag_ABI_FP_optimization_goals" },
51*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::compatibility, "Tag_compatibility" },
52*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::CPU_unaligned_access, "Tag_CPU_unaligned_access" },
53*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::FP_HP_extension, "Tag_FP_HP_extension" },
54*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_FP_16bit_format, "Tag_ABI_FP_16bit_format" },
55*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::MPextension_use, "Tag_MPextension_use" },
56*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::DIV_use, "Tag_DIV_use" },
57*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::DSP_extension, "Tag_DSP_extension" },
58*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::nodefaults, "Tag_nodefaults" },
59*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::also_compatible_with, "Tag_also_compatible_with" },
60*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::T2EE_use, "Tag_T2EE_use" },
61*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::conformance, "Tag_conformance" },
62*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::Virtualization_use, "Tag_Virtualization_use" },
63*9880d681SAndroid Build Coastguard Worker
64*9880d681SAndroid Build Coastguard Worker // Legacy Names
65*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::FP_arch, "Tag_VFP_arch" },
66*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::FP_HP_extension, "Tag_VFP_HP_extension" },
67*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_align_needed, "Tag_ABI_align8_needed" },
68*9880d681SAndroid Build Coastguard Worker { ARMBuildAttrs::ABI_align_preserved, "Tag_ABI_align8_preserved" },
69*9880d681SAndroid Build Coastguard Worker };
70*9880d681SAndroid Build Coastguard Worker }
71*9880d681SAndroid Build Coastguard Worker
72*9880d681SAndroid Build Coastguard Worker namespace llvm {
73*9880d681SAndroid Build Coastguard Worker namespace ARMBuildAttrs {
AttrTypeAsString(unsigned Attr,bool HasTagPrefix)74*9880d681SAndroid Build Coastguard Worker StringRef AttrTypeAsString(unsigned Attr, bool HasTagPrefix) {
75*9880d681SAndroid Build Coastguard Worker return AttrTypeAsString(static_cast<AttrType>(Attr), HasTagPrefix);
76*9880d681SAndroid Build Coastguard Worker }
77*9880d681SAndroid Build Coastguard Worker
AttrTypeAsString(AttrType Attr,bool HasTagPrefix)78*9880d681SAndroid Build Coastguard Worker StringRef AttrTypeAsString(AttrType Attr, bool HasTagPrefix) {
79*9880d681SAndroid Build Coastguard Worker for (unsigned TI = 0, TE = sizeof(ARMAttributeTags) / sizeof(*ARMAttributeTags);
80*9880d681SAndroid Build Coastguard Worker TI != TE; ++TI)
81*9880d681SAndroid Build Coastguard Worker if (ARMAttributeTags[TI].Attr == Attr)
82*9880d681SAndroid Build Coastguard Worker return ARMAttributeTags[TI].TagName + (HasTagPrefix ? 0 : 4);
83*9880d681SAndroid Build Coastguard Worker return "";
84*9880d681SAndroid Build Coastguard Worker }
85*9880d681SAndroid Build Coastguard Worker
AttrTypeFromString(StringRef Tag)86*9880d681SAndroid Build Coastguard Worker int AttrTypeFromString(StringRef Tag) {
87*9880d681SAndroid Build Coastguard Worker bool HasTagPrefix = Tag.startswith("Tag_");
88*9880d681SAndroid Build Coastguard Worker for (unsigned TI = 0, TE = sizeof(ARMAttributeTags) / sizeof(*ARMAttributeTags);
89*9880d681SAndroid Build Coastguard Worker TI != TE; ++TI)
90*9880d681SAndroid Build Coastguard Worker if (StringRef(ARMAttributeTags[TI].TagName + (HasTagPrefix ? 0 : 4)) == Tag)
91*9880d681SAndroid Build Coastguard Worker return ARMAttributeTags[TI].Attr;
92*9880d681SAndroid Build Coastguard Worker return -1;
93*9880d681SAndroid Build Coastguard Worker }
94*9880d681SAndroid Build Coastguard Worker }
95*9880d681SAndroid Build Coastguard Worker }
96*9880d681SAndroid Build Coastguard Worker
97