diff options
| author | Joey Gouly <joey.gouly@arm.com> | 2013-06-26 16:58:26 +0000 | 
|---|---|---|
| committer | Joey Gouly <joey.gouly@arm.com> | 2013-06-26 16:58:26 +0000 | 
| commit | 849eedce9921eb8f285cd0df0ad69ee5133459d1 (patch) | |
| tree | 0ff93bb431162234ff79d7ac320add1aee418058 /lib/Target | |
| parent | 29acf7e03af9b5524daa1e7523e0296cc766ff24 (diff) | |
| download | external_llvm-849eedce9921eb8f285cd0df0ad69ee5133459d1.zip external_llvm-849eedce9921eb8f285cd0df0ad69ee5133459d1.tar.gz external_llvm-849eedce9921eb8f285cd0df0ad69ee5133459d1.tar.bz2 | |
Add a subtarget feature 'v8' to the ARM backend.
This allows for targeting the ARMv8 AArch32 variant.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184967 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target')
| -rw-r--r-- | lib/Target/ARM/ARM.td | 6 | ||||
| -rw-r--r-- | lib/Target/ARM/ARMAsmPrinter.cpp | 4 | ||||
| -rw-r--r-- | lib/Target/ARM/ARMBuildAttrs.h | 3 | ||||
| -rw-r--r-- | lib/Target/ARM/ARMInstrInfo.td | 2 | ||||
| -rw-r--r-- | lib/Target/ARM/ARMSubtarget.cpp | 1 | ||||
| -rw-r--r-- | lib/Target/ARM/ARMSubtarget.h | 5 | ||||
| -rw-r--r-- | lib/Target/ARM/AsmParser/ARMAsmParser.cpp | 3 | ||||
| -rw-r--r-- | lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp | 5 | 
8 files changed, 25 insertions, 4 deletions
| diff --git a/lib/Target/ARM/ARM.td b/lib/Target/ARM/ARM.td index 1bc9d6b..134b83c 100644 --- a/lib/Target/ARM/ARM.td +++ b/lib/Target/ARM/ARM.td @@ -138,6 +138,9 @@ def HasV6T2Ops  : SubtargetFeature<"v6t2", "HasV6T2Ops", "true",  def HasV7Ops    : SubtargetFeature<"v7", "HasV7Ops", "true",                                     "Support ARM v7 instructions",                                     [HasV6T2Ops, FeaturePerfMon]>; +def HasV8Ops    : SubtargetFeature<"v8", "HasV8Ops", "true", +                                   "Support ARM v8 instructions", +                                   [HasV7Ops]>;  //===----------------------------------------------------------------------===//  // ARM Processors supported. @@ -291,6 +294,9 @@ def : ProcessorModel<"swift",       SwiftModel,                                       FeatureDB, FeatureDSPThumb2,                                       FeatureHasRAS]>; +// V8 Processors +def : ProcNoItin<"cortex-a53",      [HasV8Ops]>; +  //===----------------------------------------------------------------------===//  // Register File Description  //===----------------------------------------------------------------------===// diff --git a/lib/Target/ARM/ARMAsmPrinter.cpp b/lib/Target/ARM/ARMAsmPrinter.cpp index f8d4da5..d5b2cf5 100644 --- a/lib/Target/ARM/ARMAsmPrinter.cpp +++ b/lib/Target/ARM/ARMAsmPrinter.cpp @@ -749,7 +749,9 @@ void ARMAsmPrinter::emitAttributes() {                                 ARMBuildAttrs::Allowed);      AttrEmitter->EmitAttribute(ARMBuildAttrs::THUMB_ISA_use,                                 ARMBuildAttrs::Allowed); -  } else if (Subtarget->hasV7Ops()) { +  } else if (Subtarget->hasV8Ops()) +    AttrEmitter->EmitAttribute(ARMBuildAttrs::CPU_arch, ARMBuildAttrs::v8); +  else if (Subtarget->hasV7Ops()) {      AttrEmitter->EmitAttribute(ARMBuildAttrs::CPU_arch, ARMBuildAttrs::v7);      AttrEmitter->EmitAttribute(ARMBuildAttrs::THUMB_ISA_use,                                 ARMBuildAttrs::AllowThumb32); diff --git a/lib/Target/ARM/ARMBuildAttrs.h b/lib/Target/ARM/ARMBuildAttrs.h index 11bd6a4..3dfa7e7 100644 --- a/lib/Target/ARM/ARMBuildAttrs.h +++ b/lib/Target/ARM/ARMBuildAttrs.h @@ -89,7 +89,8 @@ namespace ARMBuildAttrs {      v7       = 10,  // e.g. Cortex A8, Cortex M3      v6_M     = 11,  // e.g. Cortex M1      v6S_M    = 12,  // v6_M with the System extensions -    v7E_M    = 13   // v7_M with DSP extensions +    v7E_M    = 13,  // v7_M with DSP extensions +    v8       = 14   // v8, AArch32    };    enum CPUArchProfile { // (=7), uleb128  diff --git a/lib/Target/ARM/ARMInstrInfo.td b/lib/Target/ARM/ARMInstrInfo.td index 7f32c1f..ae87442 100644 --- a/lib/Target/ARM/ARMInstrInfo.td +++ b/lib/Target/ARM/ARMInstrInfo.td @@ -194,6 +194,8 @@ def HasV6T2          : Predicate<"Subtarget->hasV6T2Ops()">,  def NoV6T2           : Predicate<"!Subtarget->hasV6T2Ops()">;  def HasV7            : Predicate<"Subtarget->hasV7Ops()">,                                   AssemblerPredicate<"HasV7Ops", "armv7">; +def HasV8            : Predicate<"Subtarget->hasV8Ops()">, +                                 AssemblerPredicate<"HasV8Ops", "armv8">;  def NoVFP            : Predicate<"!Subtarget->hasVFP2()">;  def HasVFP2          : Predicate<"Subtarget->hasVFP2()">,                                   AssemblerPredicate<"FeatureVFP2", "VFP2">; diff --git a/lib/Target/ARM/ARMSubtarget.cpp b/lib/Target/ARM/ARMSubtarget.cpp index 455fe1a..3a5d4bb 100644 --- a/lib/Target/ARM/ARMSubtarget.cpp +++ b/lib/Target/ARM/ARMSubtarget.cpp @@ -77,6 +77,7 @@ void ARMSubtarget::initializeEnvironment() {    HasV6Ops = false;    HasV6T2Ops = false;    HasV7Ops = false; +  HasV8Ops = false;    HasVFPv2 = false;    HasVFPv3 = false;    HasVFPv4 = false; diff --git a/lib/Target/ARM/ARMSubtarget.h b/lib/Target/ARM/ARMSubtarget.h index bc5af96..ad9c0d0 100644 --- a/lib/Target/ARM/ARMSubtarget.h +++ b/lib/Target/ARM/ARMSubtarget.h @@ -37,7 +37,8 @@ protected:    /// ARMProcFamily - ARM processor family: Cortex-A8, Cortex-A9, and others.    ARMProcFamilyEnum ARMProcFamily; -  /// HasV4TOps, HasV5TOps, HasV5TEOps, HasV6Ops, HasV6T2Ops, HasV7Ops - +  /// HasV4TOps, HasV5TOps, HasV5TEOps, +  /// HasV6Ops, HasV6T2Ops, HasV7Ops, HasV8Ops -    /// Specify whether target support specific ARM ISA variants.    bool HasV4TOps;    bool HasV5TOps; @@ -45,6 +46,7 @@ protected:    bool HasV6Ops;    bool HasV6T2Ops;    bool HasV7Ops; +  bool HasV8Ops;    /// HasVFPv2, HasVFPv3, HasVFPv4, HasNEON - Specify what    /// floating point ISAs are supported. @@ -231,6 +233,7 @@ public:    bool hasV6Ops()   const { return HasV6Ops;   }    bool hasV6T2Ops() const { return HasV6T2Ops; }    bool hasV7Ops()   const { return HasV7Ops;  } +  bool hasV8Ops()   const { return HasV8Ops;  }    bool isCortexA5() const { return ARMProcFamily == CortexA5; }    bool isCortexA8() const { return ARMProcFamily == CortexA8; } diff --git a/lib/Target/ARM/AsmParser/ARMAsmParser.cpp b/lib/Target/ARM/AsmParser/ARMAsmParser.cpp index eda5550..ba2bf8e 100644 --- a/lib/Target/ARM/AsmParser/ARMAsmParser.cpp +++ b/lib/Target/ARM/AsmParser/ARMAsmParser.cpp @@ -161,6 +161,9 @@ class ARMAsmParser : public MCTargetAsmParser {    bool hasV7Ops() const {      return STI.getFeatureBits() & ARM::HasV7Ops;    } +  bool hasV8Ops() const { +    return STI.getFeatureBits() & ARM::HasV8Ops; +  }    bool hasARM() const {      return !(STI.getFeatureBits() & ARM::FeatureNoARM);    } diff --git a/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp b/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp index 14fd03f..caa1949 100644 --- a/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp +++ b/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp @@ -59,7 +59,10 @@ std::string ARM_MC::ParseARMTriple(StringRef TT, StringRef CPU) {    std::string ARMArchFeature;    if (Idx) {      unsigned SubVer = TT[Idx]; -    if (SubVer >= '7' && SubVer <= '9') { +    if (SubVer == '8') { +      // FIXME: Parse v8 features +      ARMArchFeature = "+v8"; +    } else if (SubVer == '7') {        if (Len >= Idx+2 && TT[Idx+1] == 'm') {          isThumb = true;          if (NoCPU) | 
