]> granicus.if.org Git - llvm/commitdiff
[AARCH64] Add support for Broadcom Vulcan
authorPankaj Gode <pankaj.gode@broadcom.com>
Mon, 20 Jun 2016 11:13:31 +0000 (11:13 +0000)
committerPankaj Gode <pankaj.gode@broadcom.com>
Mon, 20 Jun 2016 11:13:31 +0000 (11:13 +0000)
Adding core tuning support for new Broadcom Vulcan core (ARMv8.1A).

Differential Revision: http://reviews.llvm.org/D21500

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@273148 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Support/AArch64TargetParser.def
lib/Target/AArch64/AArch64.td
lib/Target/AArch64/AArch64Subtarget.cpp
lib/Target/AArch64/AArch64Subtarget.h
test/CodeGen/AArch64/cpus.ll
test/CodeGen/AArch64/remat.ll

index dadaca2c08af2c5c256c7ed3e8d90ae7cca02650..67f981b8f2fadcdb3a29c06bf72db1aae3dc23e4 100644 (file)
@@ -65,6 +65,8 @@ AARCH64_CPU_NAME("exynos-m1", AK_ARMV8A, FK_CRYPTO_NEON_FP_ARMV8, false,
                 (AArch64::AEK_SIMD | AArch64::AEK_CRC | AArch64::AEK_CRYPTO))
 AARCH64_CPU_NAME("kryo", AK_ARMV8A, FK_CRYPTO_NEON_FP_ARMV8, false,
                 (AArch64::AEK_SIMD | AArch64::AEK_CRC | AArch64::AEK_CRYPTO))
+AARCH64_CPU_NAME("vulcan", AK_ARMV8_1A, FK_CRYPTO_NEON_FP_ARMV8, false,
+                (AArch64::AEK_SIMD | AArch64::AEK_CRC | AArch64::AEK_CRYPTO))
 // Invalid CPU
 AARCH64_CPU_NAME("invalid", AK_INVALID, FK_INVALID, true, AArch64::AEK_INVALID)
 #undef AARCH64_CPU_NAME
index a447de566adc70175b31a70a228875420ad95001..954da543d94113ae6c8d08786699264b0c3d4068 100644 (file)
@@ -215,6 +215,14 @@ def ProcKryo    : SubtargetFeature<"kryo", "ARMProcFamily", "Kryo",
                                    FeaturePredictableSelectIsExpensive
                                    ]>;
 
+def ProcVulcan  : SubtargetFeature<"vulcan", "ARMProcFamily", "Vulcan",
+                                   "Broadcom Vulcan processors", [
+                                   FeatureFPARMv8,
+                                   FeatureNEON,
+                                   FeatureCrypto,
+                                   FeatureCRC,
+                                   HasV8_1aOps]>;
+
 def : ProcessorModel<"generic", NoSchedModel, [
                      FeatureCRC,
                      FeatureFPARMv8,
@@ -233,6 +241,7 @@ def : ProcessorModel<"cortex-a73", CortexA57Model, [ProcA57]>;
 def : ProcessorModel<"cyclone", CycloneModel, [ProcCyclone]>;
 def : ProcessorModel<"exynos-m1", ExynosM1Model, [ProcExynosM1]>;
 def : ProcessorModel<"kryo", KryoModel, [ProcKryo]>;
+def : ProcessorModel<"vulcan", NoSchedModel, [ProcVulcan]>;
 
 //===----------------------------------------------------------------------===//
 // Assembly parser
index 3354cbd1a53da217a8edb9a084d272fe05cfefdf..68c8dbfaa71b482522a1c36121656a2c0c1b0664 100644 (file)
@@ -71,6 +71,7 @@ void AArch64Subtarget::initializeProperties() {
     MaxInterleaveFactor = 4;
     VectorInsertExtractBaseCost = 2;
     break;
+  case Vulcan: break;
   case CortexA35: break;
   case CortexA53: break;
   case Others: break;
index 43d4141aadf3b197a80878a20933149642cfbb87..f16daa8b7cae623b7f58ac97163682f523e16d29 100644 (file)
@@ -41,7 +41,8 @@ public:
     CortexA57,
     Cyclone,
     ExynosM1,
-    Kryo
+    Kryo,
+    Vulcan
   };
 
 protected:
index 20e48806d322de8d3f57c5911a17312beeccae97..3296e38b64f468a1d8e8a1fbb8e82cf5ee3f75e6 100644 (file)
@@ -9,6 +9,7 @@
 ; RUN: llc < %s -mtriple=arm64-unknown-unknown -mcpu=cortex-a73 2>&1 | FileCheck %s
 ; RUN: llc < %s -mtriple=arm64-unknown-unknown -mcpu=exynos-m1 2>&1 | FileCheck %s
 ; RUN: llc < %s -mtriple=arm64-unknown-unknown -mcpu=kryo 2>&1 | FileCheck %s
+; RUN: llc < %s -mtriple=arm64-unknown-unknown -mcpu=vulcan 2>&1 | FileCheck %s
 ; RUN: llc < %s -mtriple=arm64-unknown-unknown -mcpu=invalidcpu 2>&1 | FileCheck %s --check-prefix=INVALID
 
 ; CHECK-NOT: {{.*}}  is not a recognized processor for this target
index 127a596d4bee7ac4f7fba2d4608f5d122616bea6..c4470d04ff722c5d8af3fb84cbc98791d92af2ad 100644 (file)
@@ -5,6 +5,7 @@
 ; RUN: llc -mtriple=aarch64-linux-gnuabi -mcpu=cortex-a73 -o - %s | FileCheck %s
 ; RUN: llc -mtriple=aarch64-linux-gnuabi -mcpu=exynos-m1 -o - %s | FileCheck %s
 ; RUN: llc -mtriple=aarch64-linux-gnuabi -mcpu=kryo -o - %s | FileCheck %s
+; RUN: llc -mtriple=aarch64-linux-gnuabi -mcpu=vulcan -o - %s | FileCheck %s
 
 %X = type { i64, i64, i64 }
 declare void @f(%X*)