2014-05-24 20:50:23 +08:00
|
|
|
//=- AArch64.td - Describe the AArch64 Target Machine --------*- tablegen -*-=//
|
2014-03-29 18:18:08 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
2016-06-16 01:24:52 +08:00
|
|
|
// Target-independent interfaces which we are implementing.
|
2014-03-29 18:18:08 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
include "llvm/Target/Target.td"
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
2014-05-24 20:50:23 +08:00
|
|
|
// AArch64 Subtarget features.
|
2014-03-29 18:18:08 +08:00
|
|
|
//
|
|
|
|
|
2014-04-15 01:38:00 +08:00
|
|
|
def FeatureFPARMv8 : SubtargetFeature<"fp-armv8", "HasFPARMv8", "true",
|
2014-04-19 05:22:04 +08:00
|
|
|
"Enable ARMv8 FP">;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
|
|
|
def FeatureNEON : SubtargetFeature<"neon", "HasNEON", "true",
|
|
|
|
"Enable Advanced SIMD instructions", [FeatureFPARMv8]>;
|
|
|
|
|
|
|
|
def FeatureCrypto : SubtargetFeature<"crypto", "HasCrypto", "true",
|
2017-04-05 18:44:38 +08:00
|
|
|
"Enable cryptographic instructions", [FeatureNEON]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
2014-04-25 17:25:42 +08:00
|
|
|
def FeatureCRC : SubtargetFeature<"crc", "HasCRC", "true",
|
|
|
|
"Enable ARMv8 CRC-32 checksum instructions">;
|
|
|
|
|
2016-06-03 22:03:27 +08:00
|
|
|
def FeatureRAS : SubtargetFeature<"ras", "HasRAS", "true",
|
|
|
|
"Enable ARMv8 Reliability, Availability and Serviceability Extensions">;
|
|
|
|
|
2016-12-01 06:25:24 +08:00
|
|
|
def FeatureLSE : SubtargetFeature<"lse", "HasLSE", "true",
|
|
|
|
"Enable ARMv8.1 Large System Extension (LSE) atomic instructions">;
|
|
|
|
|
2017-01-17 00:28:43 +08:00
|
|
|
def FeatureRDM : SubtargetFeature<"rdm", "HasRDM", "true",
|
|
|
|
"Enable ARMv8.1 Rounding Double Multiply Add/Subtract instructions">;
|
|
|
|
|
2015-09-02 00:23:45 +08:00
|
|
|
def FeaturePerfMon : SubtargetFeature<"perfmon", "HasPerfMon", "true",
|
|
|
|
"Enable ARMv8 PMUv3 Performance Monitors extension">;
|
|
|
|
|
2015-11-26 23:23:32 +08:00
|
|
|
def FeatureFullFP16 : SubtargetFeature<"fullfp16", "HasFullFP16", "true",
|
|
|
|
"Full FP16", [FeatureFPARMv8]>;
|
|
|
|
|
2015-12-01 18:48:51 +08:00
|
|
|
def FeatureSPE : SubtargetFeature<"spe", "HasSPE", "true",
|
|
|
|
"Enable Statistical Profiling extension">;
|
|
|
|
|
2017-07-13 23:19:56 +08:00
|
|
|
def FeatureSVE : SubtargetFeature<"sve", "HasSVE", "true",
|
|
|
|
"Enable Scalable Vector Extension (SVE) instructions">;
|
|
|
|
|
2014-03-29 18:18:08 +08:00
|
|
|
/// Cyclone has register move instructions which are "free".
|
|
|
|
def FeatureZCRegMove : SubtargetFeature<"zcm", "HasZeroCycleRegMove", "true",
|
2014-05-06 05:50:57 +08:00
|
|
|
"Has zero-cycle register moves">;
|
2014-03-29 18:18:08 +08:00
|
|
|
|
|
|
|
/// Cyclone has instructions which zero registers for "free".
|
|
|
|
def FeatureZCZeroing : SubtargetFeature<"zcz", "HasZeroCycleZeroing", "true",
|
|
|
|
"Has zero-cycle zeroing instructions">;
|
|
|
|
|
2017-12-18 18:36:00 +08:00
|
|
|
/// ... but the floating-point version doesn't quite work in rare cases on older
|
|
|
|
/// CPUs.
|
|
|
|
def FeatureZCZeroingFPWorkaround : SubtargetFeature<"zcz-fp-workaround",
|
|
|
|
"HasZeroCycleZeroingFPWorkaround", "true",
|
|
|
|
"The zero-cycle floating-point zeroing instruction has a bug">;
|
|
|
|
|
2015-07-29 22:17:26 +08:00
|
|
|
def FeatureStrictAlign : SubtargetFeature<"strict-align",
|
|
|
|
"StrictAlign", "true",
|
|
|
|
"Disallow all unaligned memory "
|
|
|
|
"access">;
|
|
|
|
|
2015-07-25 08:18:31 +08:00
|
|
|
def FeatureReserveX18 : SubtargetFeature<"reserve-x18", "ReserveX18", "true",
|
|
|
|
"Reserve X18, making it unavailable "
|
|
|
|
"as a GPR">;
|
|
|
|
|
2016-06-03 02:03:53 +08:00
|
|
|
def FeatureUseAA : SubtargetFeature<"use-aa", "UseAA", "true",
|
|
|
|
"Use alias analysis during codegen">;
|
|
|
|
|
|
|
|
def FeatureBalanceFPOps : SubtargetFeature<"balance-fp-ops", "BalanceFPOps",
|
|
|
|
"true",
|
|
|
|
"balance mix of odd and even D-registers for fp multiply(-accumulate) ops">;
|
|
|
|
|
|
|
|
def FeaturePredictableSelectIsExpensive : SubtargetFeature<
|
|
|
|
"predictable-select-expensive", "PredictableSelectIsExpensive", "true",
|
|
|
|
"Prefer likely predicted branches over selects">;
|
|
|
|
|
|
|
|
def FeatureCustomCheapAsMoveHandling : SubtargetFeature<"custom-cheap-as-move",
|
|
|
|
"CustomAsCheapAsMove", "true",
|
|
|
|
"Use custom code for TargetInstrInfo::isAsCheapAsAMove()">;
|
|
|
|
|
2018-01-30 23:40:22 +08:00
|
|
|
def FeatureExynosCheapAsMoveHandling : SubtargetFeature<"exynos-cheap-as-move",
|
|
|
|
"ExynosAsCheapAsMove", "true",
|
|
|
|
"Use Exynos specific code in TargetInstrInfo::isAsCheapAsAMove()",
|
|
|
|
[FeatureCustomCheapAsMoveHandling]>;
|
|
|
|
|
2016-06-03 02:03:53 +08:00
|
|
|
def FeaturePostRAScheduler : SubtargetFeature<"use-postra-scheduler",
|
|
|
|
"UsePostRAScheduler", "true", "Schedule again after register allocation">;
|
|
|
|
|
|
|
|
def FeatureSlowMisaligned128Store : SubtargetFeature<"slow-misaligned-128store",
|
|
|
|
"Misaligned128StoreIsSlow", "true", "Misaligned 128 bit stores are slow">;
|
|
|
|
|
2017-01-25 01:34:31 +08:00
|
|
|
def FeatureSlowPaired128 : SubtargetFeature<"slow-paired-128",
|
|
|
|
"Paired128IsSlow", "true", "Paired 128 bit loads and stores are slow">;
|
2016-06-03 02:03:53 +08:00
|
|
|
|
2017-08-29 04:48:43 +08:00
|
|
|
def FeatureSlowSTRQro : SubtargetFeature<"slow-strqro-store", "STRQroIsSlow",
|
|
|
|
"true", "STR of Q register with register offset is slow">;
|
|
|
|
|
2016-06-03 02:03:53 +08:00
|
|
|
def FeatureAlternateSExtLoadCVTF32Pattern : SubtargetFeature<
|
|
|
|
"alternate-sextload-cvt-f32-pattern", "UseAlternateSExtLoadCVTF32Pattern",
|
|
|
|
"true", "Use alternative pattern for sextload convert to f32">;
|
|
|
|
|
2016-10-05 03:28:21 +08:00
|
|
|
def FeatureArithmeticBccFusion : SubtargetFeature<
|
|
|
|
"arith-bcc-fusion", "HasArithmeticBccFusion", "true",
|
|
|
|
"CPU fuses arithmetic+bcc operations">;
|
|
|
|
|
|
|
|
def FeatureArithmeticCbzFusion : SubtargetFeature<
|
|
|
|
"arith-cbz-fusion", "HasArithmeticCbzFusion", "true",
|
|
|
|
"CPU fuses arithmetic + cbz/cbnz operations">;
|
2016-06-03 02:03:53 +08:00
|
|
|
|
2018-01-31 00:28:01 +08:00
|
|
|
def FeatureFuseAddress : SubtargetFeature<
|
|
|
|
"fuse-address", "HasFuseAddress", "true",
|
|
|
|
"CPU fuses address generation and memory operations">;
|
|
|
|
|
2017-02-01 10:54:39 +08:00
|
|
|
def FeatureFuseAES : SubtargetFeature<
|
|
|
|
"fuse-aes", "HasFuseAES", "true",
|
|
|
|
"CPU fuses AES crypto operations">;
|
|
|
|
|
2018-02-24 03:27:43 +08:00
|
|
|
def FeatureFuseCCSelect : SubtargetFeature<
|
|
|
|
"fuse-csel", "HasFuseCCSelect", "true",
|
|
|
|
"CPU fuses conditional select operations">;
|
|
|
|
|
2017-02-01 10:54:42 +08:00
|
|
|
def FeatureFuseLiterals : SubtargetFeature<
|
|
|
|
"fuse-literals", "HasFuseLiterals", "true",
|
|
|
|
"CPU fuses literal generation operations">;
|
|
|
|
|
2016-06-03 02:03:53 +08:00
|
|
|
def FeatureDisableLatencySchedHeuristic : SubtargetFeature<
|
|
|
|
"disable-latency-sched-heuristic", "DisableLatencySchedHeuristic", "true",
|
|
|
|
"Disable latency scheduling heuristic">;
|
|
|
|
|
2017-08-10 17:52:55 +08:00
|
|
|
def FeatureRCPC : SubtargetFeature<"rcpc", "HasRCPC", "true",
|
|
|
|
"Enable support for RCPC extension">;
|
|
|
|
|
2016-10-25 00:14:58 +08:00
|
|
|
def FeatureUseRSqrt : SubtargetFeature<
|
|
|
|
"use-reciprocal-square-root", "UseRSqrt", "true",
|
|
|
|
"Use the reciprocal square root approximation">;
|
2017-03-28 18:02:56 +08:00
|
|
|
|
2017-08-09 22:59:54 +08:00
|
|
|
def FeatureDotProd : SubtargetFeature<
|
|
|
|
"dotprod", "HasDotProd", "true",
|
|
|
|
"Enable dot product support">;
|
|
|
|
|
2017-03-28 18:02:56 +08:00
|
|
|
def FeatureNoNegativeImmediates : SubtargetFeature<"no-neg-immediates",
|
|
|
|
"NegativeImmediates", "false",
|
|
|
|
"Convert immediates and instructions "
|
|
|
|
"to their negated or complemented "
|
|
|
|
"equivalent when the immediate does "
|
|
|
|
"not fit in the encoding.">;
|
|
|
|
|
2017-04-01 02:16:53 +08:00
|
|
|
def FeatureLSLFast : SubtargetFeature<
|
|
|
|
"lsl-fast", "HasLSLFast", "true",
|
|
|
|
"CPU has a fastpath logical shift of up to 3 places">;
|
2017-12-15 07:06:18 +08:00
|
|
|
|
2018-01-26 05:55:39 +08:00
|
|
|
def FeatureAggressiveFMA :
|
|
|
|
SubtargetFeature<"aggressive-fma",
|
|
|
|
"HasAggressiveFMA",
|
|
|
|
"true",
|
|
|
|
"Enable Aggressive FMA for floating-point.">;
|
|
|
|
|
2015-04-01 22:49:29 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Architectures.
|
|
|
|
//
|
|
|
|
|
|
|
|
def HasV8_1aOps : SubtargetFeature<"v8.1a", "HasV8_1aOps", "true",
|
2017-01-17 00:28:43 +08:00
|
|
|
"Support ARM v8.1a instructions", [FeatureCRC, FeatureLSE, FeatureRDM]>;
|
2015-04-01 22:49:29 +08:00
|
|
|
|
2015-11-26 23:23:32 +08:00
|
|
|
def HasV8_2aOps : SubtargetFeature<"v8.2a", "HasV8_2aOps", "true",
|
2016-06-03 22:03:27 +08:00
|
|
|
"Support ARM v8.2a instructions", [HasV8_1aOps, FeatureRAS]>;
|
2015-11-26 23:23:32 +08:00
|
|
|
|
2017-08-10 17:41:00 +08:00
|
|
|
def HasV8_3aOps : SubtargetFeature<"v8.3a", "HasV8_3aOps", "true",
|
2017-08-10 17:52:55 +08:00
|
|
|
"Support ARM v8.3a instructions", [HasV8_2aOps, FeatureRCPC]>;
|
2017-08-10 17:41:00 +08:00
|
|
|
|
2014-03-29 18:18:08 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Register File Description
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-05-24 20:50:23 +08:00
|
|
|
include "AArch64RegisterInfo.td"
|
Re-commit: [globalisel] Tablegen-erate current Register Bank Information
Summary:
Adds a RegisterBank tablegen class that can be used to declare the register
banks and an associated tablegen pass to generate the necessary code.
Changes since first commit attempt:
* Added missing guards
* Added more missing guards
* Found and fixed a use-after-free bug involving Twine locals
Reviewers: t.p.northover, ab, rovka, qcolombet
Reviewed By: qcolombet
Subscribers: aditya_nandakumar, rengolin, kristof.beyls, vkalintiris, mgorny, dberris, llvm-commits, rovka
Differential Revision: https://reviews.llvm.org/D27338
llvm-svn: 292478
2017-01-19 19:15:55 +08:00
|
|
|
include "AArch64RegisterBanks.td"
|
2014-05-24 20:50:23 +08:00
|
|
|
include "AArch64CallingConvention.td"
|
2014-03-29 18:18:08 +08:00
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Instruction Descriptions
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-05-24 20:50:23 +08:00
|
|
|
include "AArch64Schedule.td"
|
|
|
|
include "AArch64InstrInfo.td"
|
2014-03-29 18:18:08 +08:00
|
|
|
|
2014-05-24 20:50:23 +08:00
|
|
|
def AArch64InstrInfo : InstrInfo;
|
2014-03-29 18:18:08 +08:00
|
|
|
|
2016-07-06 05:23:04 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Named operands for MRS/MSR/TLBI/...
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
include "AArch64SystemOperands.td"
|
|
|
|
|
2014-03-29 18:18:08 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2014-05-24 20:50:23 +08:00
|
|
|
// AArch64 Processors supported.
|
2014-03-29 18:18:08 +08:00
|
|
|
//
|
2014-05-24 20:50:23 +08:00
|
|
|
include "AArch64SchedA53.td"
|
2014-06-12 05:06:56 +08:00
|
|
|
include "AArch64SchedA57.td"
|
2014-05-24 20:50:23 +08:00
|
|
|
include "AArch64SchedCyclone.td"
|
2016-11-30 04:00:27 +08:00
|
|
|
include "AArch64SchedFalkor.td"
|
2016-02-12 23:51:51 +08:00
|
|
|
include "AArch64SchedKryo.td"
|
2018-01-30 04:22:24 +08:00
|
|
|
include "AArch64SchedExynosM1.td"
|
2018-01-30 23:40:16 +08:00
|
|
|
include "AArch64SchedExynosM3.td"
|
2017-02-18 02:34:24 +08:00
|
|
|
include "AArch64SchedThunderX.td"
|
2017-03-08 03:42:40 +08:00
|
|
|
include "AArch64SchedThunderX2T99.td"
|
2014-03-29 18:18:08 +08:00
|
|
|
|
2015-12-02 19:53:44 +08:00
|
|
|
def ProcA35 : SubtargetFeature<"a35", "ARMProcFamily", "CortexA35",
|
2016-06-03 02:03:53 +08:00
|
|
|
"Cortex-A35 ARM processors", [
|
2015-12-02 19:53:44 +08:00
|
|
|
FeatureCRC,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon
|
|
|
|
]>;
|
2015-12-02 19:53:44 +08:00
|
|
|
|
2014-04-15 01:38:00 +08:00
|
|
|
def ProcA53 : SubtargetFeature<"a53", "ARMProcFamily", "CortexA53",
|
2016-06-03 02:03:53 +08:00
|
|
|
"Cortex-A53 ARM processors", [
|
|
|
|
FeatureBalanceFPOps,
|
2015-09-02 00:23:45 +08:00
|
|
|
FeatureCRC,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureCustomCheapAsMoveHandling,
|
|
|
|
FeatureFPARMv8,
|
2017-05-31 23:50:03 +08:00
|
|
|
FeatureFuseAES,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeatureUseAA
|
|
|
|
]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
2017-08-21 16:43:06 +08:00
|
|
|
def ProcA55 : SubtargetFeature<"a55", "ARMProcFamily", "CortexA55",
|
|
|
|
"Cortex-A55 ARM processors", [
|
2017-09-18 22:46:14 +08:00
|
|
|
HasV8_2aOps,
|
2017-08-21 16:43:06 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureFuseAES,
|
|
|
|
FeatureNEON,
|
|
|
|
FeatureFullFP16,
|
|
|
|
FeatureDotProd,
|
|
|
|
FeatureRCPC,
|
|
|
|
FeaturePerfMon
|
|
|
|
]>;
|
|
|
|
|
2014-04-15 01:38:00 +08:00
|
|
|
def ProcA57 : SubtargetFeature<"a57", "ARMProcFamily", "CortexA57",
|
2016-06-03 02:03:53 +08:00
|
|
|
"Cortex-A57 ARM processors", [
|
|
|
|
FeatureBalanceFPOps,
|
2015-09-02 00:23:45 +08:00
|
|
|
FeatureCRC,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureCustomCheapAsMoveHandling,
|
|
|
|
FeatureFPARMv8,
|
2017-02-01 10:54:39 +08:00
|
|
|
FeatureFuseAES,
|
2017-02-01 10:54:42 +08:00
|
|
|
FeatureFuseLiterals,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive
|
|
|
|
]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
[AArch64] Restore codegen for AArch64 Cortex-A72/A73 after NFCI
Summary:
Code generation for Cortex-A72/Cortex-A73 was accidentally changed
by r271555, which was a NFCI. The isCortexA57() predicate was not true
for Cortex-A72/Cortex-A73 before r271555 (since it was checking the CPU
string). Because Cortex-A72/Cortex-A73 inherit all features from Cortex-A57,
all decisions previously guarded by isCortexA57() are now taken.
This change restores the behaviour before r271555 by adding separate
ProcA72/ProcA73, which have the required features to preserve code
generation.
Reviewers: kristof.beyls, aadg, mcrosier, rengolin
Subscribers: mcrosier, llvm-commits, aemerson, t.p.northover, MatzeB, rengolin
Differential Revision: http://reviews.llvm.org/D21182
llvm-svn: 273277
2016-06-21 23:53:54 +08:00
|
|
|
def ProcA72 : SubtargetFeature<"a72", "ARMProcFamily", "CortexA72",
|
|
|
|
"Cortex-A72 ARM processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
2017-05-15 23:15:22 +08:00
|
|
|
FeatureFuseAES,
|
[AArch64] Restore codegen for AArch64 Cortex-A72/A73 after NFCI
Summary:
Code generation for Cortex-A72/Cortex-A73 was accidentally changed
by r271555, which was a NFCI. The isCortexA57() predicate was not true
for Cortex-A72/Cortex-A73 before r271555 (since it was checking the CPU
string). Because Cortex-A72/Cortex-A73 inherit all features from Cortex-A57,
all decisions previously guarded by isCortexA57() are now taken.
This change restores the behaviour before r271555 by adding separate
ProcA72/ProcA73, which have the required features to preserve code
generation.
Reviewers: kristof.beyls, aadg, mcrosier, rengolin
Subscribers: mcrosier, llvm-commits, aemerson, t.p.northover, MatzeB, rengolin
Differential Revision: http://reviews.llvm.org/D21182
llvm-svn: 273277
2016-06-21 23:53:54 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon
|
|
|
|
]>;
|
|
|
|
|
|
|
|
def ProcA73 : SubtargetFeature<"a73", "ARMProcFamily", "CortexA73",
|
|
|
|
"Cortex-A73 ARM processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
2017-05-31 23:25:25 +08:00
|
|
|
FeatureFuseAES,
|
[AArch64] Restore codegen for AArch64 Cortex-A72/A73 after NFCI
Summary:
Code generation for Cortex-A72/Cortex-A73 was accidentally changed
by r271555, which was a NFCI. The isCortexA57() predicate was not true
for Cortex-A72/Cortex-A73 before r271555 (since it was checking the CPU
string). Because Cortex-A72/Cortex-A73 inherit all features from Cortex-A57,
all decisions previously guarded by isCortexA57() are now taken.
This change restores the behaviour before r271555 by adding separate
ProcA72/ProcA73, which have the required features to preserve code
generation.
Reviewers: kristof.beyls, aadg, mcrosier, rengolin
Subscribers: mcrosier, llvm-commits, aemerson, t.p.northover, MatzeB, rengolin
Differential Revision: http://reviews.llvm.org/D21182
llvm-svn: 273277
2016-06-21 23:53:54 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon
|
|
|
|
]>;
|
|
|
|
|
2017-08-21 16:43:06 +08:00
|
|
|
def ProcA75 : SubtargetFeature<"a75", "ARMProcFamily", "CortexA75",
|
|
|
|
"Cortex-A75 ARM processors", [
|
2017-09-18 22:46:14 +08:00
|
|
|
HasV8_2aOps,
|
2017-08-21 16:43:06 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureFuseAES,
|
|
|
|
FeatureNEON,
|
|
|
|
FeatureFullFP16,
|
|
|
|
FeatureDotProd,
|
|
|
|
FeatureRCPC,
|
|
|
|
FeaturePerfMon
|
|
|
|
]>;
|
|
|
|
|
2017-10-18 05:46:15 +08:00
|
|
|
// Note that cyclone does not fuse AES instructions, but newer apple chips do
|
|
|
|
// perform the fusion and cyclone is used by default when targetting apple OSes.
|
2014-04-15 01:38:00 +08:00
|
|
|
def ProcCyclone : SubtargetFeature<"cyclone", "ARMProcFamily", "Cyclone",
|
2016-06-03 02:03:53 +08:00
|
|
|
"Cyclone", [
|
|
|
|
FeatureAlternateSExtLoadCVTF32Pattern,
|
2017-10-18 05:46:15 +08:00
|
|
|
FeatureArithmeticBccFusion,
|
|
|
|
FeatureArithmeticCbzFusion,
|
2014-04-15 01:38:00 +08:00
|
|
|
FeatureCrypto,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureDisableLatencySchedHeuristic,
|
|
|
|
FeatureFPARMv8,
|
2017-10-18 05:46:15 +08:00
|
|
|
FeatureFuseAES,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureNEON,
|
2015-09-02 00:23:45 +08:00
|
|
|
FeaturePerfMon,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureZCRegMove,
|
2017-12-18 18:36:00 +08:00
|
|
|
FeatureZCZeroing,
|
|
|
|
FeatureZCZeroingFPWorkaround
|
2016-06-03 02:03:53 +08:00
|
|
|
]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
2016-01-05 20:51:59 +08:00
|
|
|
def ProcExynosM1 : SubtargetFeature<"exynosm1", "ARMProcFamily", "ExynosM1",
|
2016-10-27 06:06:20 +08:00
|
|
|
"Samsung Exynos-M1 processors",
|
2017-01-25 01:34:31 +08:00
|
|
|
[FeatureSlowPaired128,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
2018-01-30 23:40:22 +08:00
|
|
|
FeatureExynosCheapAsMoveHandling,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureFPARMv8,
|
2017-02-01 10:54:39 +08:00
|
|
|
FeatureFuseAES,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
2016-12-16 08:18:00 +08:00
|
|
|
FeatureSlowMisaligned128Store,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureUseRSqrt,
|
|
|
|
FeatureZCZeroing]>;
|
|
|
|
|
|
|
|
def ProcExynosM2 : SubtargetFeature<"exynosm2", "ARMProcFamily", "ExynosM1",
|
2018-01-23 03:03:26 +08:00
|
|
|
"Samsung Exynos-M2 processors",
|
2017-01-25 01:34:31 +08:00
|
|
|
[FeatureSlowPaired128,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
2018-01-30 23:40:22 +08:00
|
|
|
FeatureExynosCheapAsMoveHandling,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureFPARMv8,
|
2017-07-19 06:51:25 +08:00
|
|
|
FeatureFuseAES,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
2016-12-16 08:18:00 +08:00
|
|
|
FeatureSlowMisaligned128Store,
|
2016-10-27 06:06:20 +08:00
|
|
|
FeatureZCZeroing]>;
|
2016-01-05 20:51:59 +08:00
|
|
|
|
2018-01-30 23:40:16 +08:00
|
|
|
def ProcExynosM3 : SubtargetFeature<"exynosm3", "ARMProcFamily", "ExynosM3",
|
2018-01-23 03:03:26 +08:00
|
|
|
"Samsung Exynos-M3 processors",
|
|
|
|
[FeatureCRC,
|
|
|
|
FeatureCrypto,
|
2018-01-30 23:40:22 +08:00
|
|
|
FeatureExynosCheapAsMoveHandling,
|
2018-01-23 03:03:26 +08:00
|
|
|
FeatureFPARMv8,
|
2018-01-31 00:28:01 +08:00
|
|
|
FeatureFuseAddress,
|
2018-01-23 03:03:26 +08:00
|
|
|
FeatureFuseAES,
|
2018-02-24 03:27:43 +08:00
|
|
|
FeatureFuseCCSelect,
|
2018-01-23 03:03:26 +08:00
|
|
|
FeatureFuseLiterals,
|
2018-01-30 23:40:16 +08:00
|
|
|
FeatureLSLFast,
|
2018-01-23 03:03:26 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
2018-01-30 23:40:16 +08:00
|
|
|
FeaturePredictableSelectIsExpensive,
|
2018-01-23 03:03:26 +08:00
|
|
|
FeatureZCZeroing]>;
|
|
|
|
|
2016-02-12 23:51:51 +08:00
|
|
|
def ProcKryo : SubtargetFeature<"kryo", "ARMProcFamily", "Kryo",
|
2016-06-03 02:03:53 +08:00
|
|
|
"Qualcomm Kryo processors", [
|
2016-02-12 23:51:51 +08:00
|
|
|
FeatureCRC,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureCrypto,
|
|
|
|
FeatureCustomCheapAsMoveHandling,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
2016-07-12 10:04:01 +08:00
|
|
|
FeaturePredictableSelectIsExpensive,
|
2017-04-01 02:16:53 +08:00
|
|
|
FeatureZCZeroing,
|
|
|
|
FeatureLSLFast
|
2016-06-03 02:03:53 +08:00
|
|
|
]>;
|
|
|
|
|
2016-11-16 05:34:12 +08:00
|
|
|
def ProcFalkor : SubtargetFeature<"falkor", "ARMProcFamily", "Falkor",
|
|
|
|
"Qualcomm Falkor processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
2017-01-05 05:26:23 +08:00
|
|
|
FeatureCustomCheapAsMoveHandling,
|
2016-11-16 05:34:12 +08:00
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureNEON,
|
2017-01-05 05:26:23 +08:00
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
2017-01-17 00:28:43 +08:00
|
|
|
FeatureRDM,
|
2017-04-01 02:16:53 +08:00
|
|
|
FeatureZCZeroing,
|
2017-08-29 04:48:43 +08:00
|
|
|
FeatureLSLFast,
|
|
|
|
FeatureSlowSTRQro
|
2016-11-16 05:34:12 +08:00
|
|
|
]>;
|
|
|
|
|
2017-09-25 22:05:00 +08:00
|
|
|
def ProcSaphira : SubtargetFeature<"saphira", "ARMProcFamily", "Saphira",
|
|
|
|
"Qualcomm Saphira processors", [
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureCustomCheapAsMoveHandling,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureNEON,
|
|
|
|
FeatureSPE,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureZCZeroing,
|
|
|
|
FeatureLSLFast,
|
|
|
|
HasV8_3aOps]>;
|
|
|
|
|
2017-03-08 03:42:40 +08:00
|
|
|
def ProcThunderX2T99 : SubtargetFeature<"thunderx2t99", "ARMProcFamily",
|
|
|
|
"ThunderX2T99",
|
|
|
|
"Cavium ThunderX2 processors", [
|
2018-01-26 05:55:39 +08:00
|
|
|
FeatureAggressiveFMA,
|
2017-03-08 03:42:40 +08:00
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeatureArithmeticBccFusion,
|
|
|
|
FeatureNEON,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureLSE,
|
|
|
|
HasV8_1aOps]>;
|
2016-06-20 19:13:31 +08:00
|
|
|
|
2017-02-18 02:34:24 +08:00
|
|
|
def ProcThunderX : SubtargetFeature<"thunderx", "ARMProcFamily", "ThunderX",
|
|
|
|
"Cavium ThunderX processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureNEON]>;
|
|
|
|
|
|
|
|
def ProcThunderXT88 : SubtargetFeature<"thunderxt88", "ARMProcFamily",
|
|
|
|
"ThunderXT88",
|
|
|
|
"Cavium ThunderX processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureNEON]>;
|
|
|
|
|
|
|
|
def ProcThunderXT81 : SubtargetFeature<"thunderxt81", "ARMProcFamily",
|
|
|
|
"ThunderXT81",
|
|
|
|
"Cavium ThunderX processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureNEON]>;
|
|
|
|
|
|
|
|
def ProcThunderXT83 : SubtargetFeature<"thunderxt83", "ARMProcFamily",
|
|
|
|
"ThunderXT83",
|
|
|
|
"Cavium ThunderX processors", [
|
|
|
|
FeatureCRC,
|
|
|
|
FeatureCrypto,
|
|
|
|
FeatureFPARMv8,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler,
|
|
|
|
FeaturePredictableSelectIsExpensive,
|
|
|
|
FeatureNEON]>;
|
|
|
|
|
2016-06-03 02:03:53 +08:00
|
|
|
def : ProcessorModel<"generic", NoSchedModel, [
|
|
|
|
FeatureFPARMv8,
|
[AArch64] Enable FeatureFuseAES for the generic processor model.
Summary:
Scheduling AESE/AESMC and AESD/AESIMC instruction pairs back-to-back
gives a double digit speedup on benchmarks using those instructions on
Cortex-A processors. In GCC, this optimization is part of the generic
processor model as well.
This change should not have a major performance impact on processors
that do not optimize AES instruction pairs, although I only had access
to Cortex-A processors for benchmarking.
Reviewers: rengolin, kristof.beyls, javed.absar, evandro, silviu.baranga, MatzeB, mcrosier, joelkevinjones, joel_k_jones, bmakam, t.p.northover
Reviewed By: evandro
Subscribers: sbaranga, aemerson, llvm-commits
Differential Revision: https://reviews.llvm.org/D33836
llvm-svn: 305457
2017-06-15 17:31:23 +08:00
|
|
|
FeatureFuseAES,
|
2016-06-03 02:03:53 +08:00
|
|
|
FeatureNEON,
|
|
|
|
FeaturePerfMon,
|
|
|
|
FeaturePostRAScheduler
|
|
|
|
]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
|
2017-08-21 16:43:06 +08:00
|
|
|
// FIXME: Cortex-A35 and Cortex-A55 are currently modeled as a Cortex-A53.
|
2015-12-02 19:53:44 +08:00
|
|
|
def : ProcessorModel<"cortex-a35", CortexA53Model, [ProcA35]>;
|
2014-04-19 05:22:04 +08:00
|
|
|
def : ProcessorModel<"cortex-a53", CortexA53Model, [ProcA53]>;
|
2017-08-21 16:43:06 +08:00
|
|
|
def : ProcessorModel<"cortex-a55", CortexA53Model, [ProcA55]>;
|
2014-06-12 05:06:56 +08:00
|
|
|
def : ProcessorModel<"cortex-a57", CortexA57Model, [ProcA57]>;
|
2017-08-21 16:43:06 +08:00
|
|
|
// FIXME: Cortex-A72, Cortex-A73 and Cortex-A75 are currently modeled as a Cortex-A57.
|
[AArch64] Restore codegen for AArch64 Cortex-A72/A73 after NFCI
Summary:
Code generation for Cortex-A72/Cortex-A73 was accidentally changed
by r271555, which was a NFCI. The isCortexA57() predicate was not true
for Cortex-A72/Cortex-A73 before r271555 (since it was checking the CPU
string). Because Cortex-A72/Cortex-A73 inherit all features from Cortex-A57,
all decisions previously guarded by isCortexA57() are now taken.
This change restores the behaviour before r271555 by adding separate
ProcA72/ProcA73, which have the required features to preserve code
generation.
Reviewers: kristof.beyls, aadg, mcrosier, rengolin
Subscribers: mcrosier, llvm-commits, aemerson, t.p.northover, MatzeB, rengolin
Differential Revision: http://reviews.llvm.org/D21182
llvm-svn: 273277
2016-06-21 23:53:54 +08:00
|
|
|
def : ProcessorModel<"cortex-a72", CortexA57Model, [ProcA72]>;
|
|
|
|
def : ProcessorModel<"cortex-a73", CortexA57Model, [ProcA73]>;
|
2017-08-21 16:43:06 +08:00
|
|
|
def : ProcessorModel<"cortex-a75", CortexA57Model, [ProcA75]>;
|
2014-04-15 01:38:00 +08:00
|
|
|
def : ProcessorModel<"cyclone", CycloneModel, [ProcCyclone]>;
|
2016-02-06 08:01:41 +08:00
|
|
|
def : ProcessorModel<"exynos-m1", ExynosM1Model, [ProcExynosM1]>;
|
2016-10-27 06:06:20 +08:00
|
|
|
def : ProcessorModel<"exynos-m2", ExynosM1Model, [ProcExynosM2]>;
|
2018-01-30 23:40:16 +08:00
|
|
|
def : ProcessorModel<"exynos-m3", ExynosM3Model, [ProcExynosM3]>;
|
2016-11-30 04:00:27 +08:00
|
|
|
def : ProcessorModel<"falkor", FalkorModel, [ProcFalkor]>;
|
2017-09-25 22:05:00 +08:00
|
|
|
def : ProcessorModel<"saphira", FalkorModel, [ProcSaphira]>;
|
2016-02-12 23:51:51 +08:00
|
|
|
def : ProcessorModel<"kryo", KryoModel, [ProcKryo]>;
|
2017-02-18 02:34:24 +08:00
|
|
|
// Cavium ThunderX/ThunderX T8X Processors
|
|
|
|
def : ProcessorModel<"thunderx", ThunderXT8XModel, [ProcThunderX]>;
|
|
|
|
def : ProcessorModel<"thunderxt88", ThunderXT8XModel, [ProcThunderXT88]>;
|
|
|
|
def : ProcessorModel<"thunderxt81", ThunderXT8XModel, [ProcThunderXT81]>;
|
|
|
|
def : ProcessorModel<"thunderxt83", ThunderXT8XModel, [ProcThunderXT83]>;
|
2017-03-08 03:42:40 +08:00
|
|
|
// Cavium ThunderX2T9X Processors. Formerly Broadcom Vulcan.
|
|
|
|
def : ProcessorModel<"thunderx2t99", ThunderX2T99Model, [ProcThunderX2T99]>;
|
2014-03-29 18:18:08 +08:00
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Assembly parser
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
def GenericAsmParserVariant : AsmParserVariant {
|
|
|
|
int Variant = 0;
|
|
|
|
string Name = "generic";
|
2015-11-09 08:31:07 +08:00
|
|
|
string BreakCharacters = ".";
|
[AArch64][SVE] Asm: Add parsing of merging/zeroing suffix for SVE predicate vector operands
Summary:
Parsing of the '/m' (merging) or '/z' (zeroing) suffix of a predicate operand.
Patch [2/3] in a series to add predicated ADD/SUB instructions for SVE.
Reviewers: rengolin, mcrosier, evandro, fhahn, echristo, MatzeB, t.p.northover
Reviewed By: fhahn
Subscribers: t.p.northover, MatzeB, aemerson, javed.absar, tschuett, llvm-commits, kristof.beyls
Differential Revision: https://reviews.llvm.org/D41442
llvm-svn: 322070
2018-01-09 19:17:06 +08:00
|
|
|
string TokenizingCharacters = "[]*!/";
|
2014-03-29 18:18:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
def AppleAsmParserVariant : AsmParserVariant {
|
|
|
|
int Variant = 1;
|
|
|
|
string Name = "apple-neon";
|
2015-11-09 08:31:07 +08:00
|
|
|
string BreakCharacters = ".";
|
[AArch64][SVE] Asm: Add parsing of merging/zeroing suffix for SVE predicate vector operands
Summary:
Parsing of the '/m' (merging) or '/z' (zeroing) suffix of a predicate operand.
Patch [2/3] in a series to add predicated ADD/SUB instructions for SVE.
Reviewers: rengolin, mcrosier, evandro, fhahn, echristo, MatzeB, t.p.northover
Reviewed By: fhahn
Subscribers: t.p.northover, MatzeB, aemerson, javed.absar, tschuett, llvm-commits, kristof.beyls
Differential Revision: https://reviews.llvm.org/D41442
llvm-svn: 322070
2018-01-09 19:17:06 +08:00
|
|
|
string TokenizingCharacters = "[]*!/";
|
2014-03-29 18:18:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Assembly printer
|
|
|
|
//===----------------------------------------------------------------------===//
|
2014-05-24 20:50:23 +08:00
|
|
|
// AArch64 Uses the MC printer for asm output, so make sure the TableGen
|
2014-03-29 18:18:08 +08:00
|
|
|
// AsmWriter bits get associated with the correct class.
|
|
|
|
def GenericAsmWriter : AsmWriter {
|
|
|
|
string AsmWriterClassName = "InstPrinter";
|
2015-03-28 04:36:02 +08:00
|
|
|
int PassSubtarget = 1;
|
2014-03-29 18:18:08 +08:00
|
|
|
int Variant = 0;
|
|
|
|
bit isMCAsmWriter = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
def AppleAsmWriter : AsmWriter {
|
|
|
|
let AsmWriterClassName = "AppleInstPrinter";
|
2015-03-28 04:36:02 +08:00
|
|
|
int PassSubtarget = 1;
|
2014-03-29 18:18:08 +08:00
|
|
|
int Variant = 1;
|
|
|
|
int isMCAsmWriter = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Target Declaration
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-05-24 20:50:23 +08:00
|
|
|
def AArch64 : Target {
|
|
|
|
let InstructionSet = AArch64InstrInfo;
|
2014-03-29 18:18:08 +08:00
|
|
|
let AssemblyParserVariants = [GenericAsmParserVariant, AppleAsmParserVariant];
|
|
|
|
let AssemblyWriters = [GenericAsmWriter, AppleAsmWriter];
|
[MachineOperand][Target] MachineOperand::isRenamable semantics changes
Summary:
Add a target option AllowRegisterRenaming that is used to opt in to
post-register-allocation renaming of registers. This is set to 0 by
default, which causes the hasExtraSrcRegAllocReq/hasExtraDstRegAllocReq
fields of all opcodes to be set to 1, causing
MachineOperand::isRenamable to always return false.
Set the AllowRegisterRenaming flag to 1 for all in-tree targets that
have lit tests that were effected by enabling COPY forwarding in
MachineCopyPropagation (AArch64, AMDGPU, ARM, Hexagon, Mips, PowerPC,
RISCV, Sparc, SystemZ and X86).
Add some more comments describing the semantics of the
MachineOperand::isRenamable function and how it is set and maintained.
Change isRenamable to check the operand's opcode
hasExtraSrcRegAllocReq/hasExtraDstRegAllocReq bit directly instead of
relying on it being consistently reflected in the IsRenamable bit
setting.
Clear the IsRenamable bit when changing an operand's register value.
Remove target code that was clearing the IsRenamable bit when changing
registers/opcodes now that this is done conservatively by default.
Change setting of hasExtraSrcRegAllocReq in AMDGPU target to be done in
one place covering all opcodes that have constant pipe read limit
restrictions.
Reviewers: qcolombet, MatzeB
Subscribers: aemerson, arsenm, jyknight, mcrosier, sdardis, nhaehnle, javed.absar, tpr, arichardson, kristof.beyls, kbarton, fedor.sergeev, asb, rbar, johnrusso, simoncook, jordy.potman.lists, apazos, sabuasal, niosHD, escha, nemanjai, llvm-commits
Differential Revision: https://reviews.llvm.org/D43042
llvm-svn: 325931
2018-02-24 02:25:08 +08:00
|
|
|
let AllowRegisterRenaming = 1;
|
2014-03-29 18:18:08 +08:00
|
|
|
}
|