13#ifndef LLVM_LIB_TARGET_RISCV_RISCVSUBTARGET_H
14#define LLVM_LIB_TARGET_RISCV_RISCVSUBTARGET_H
33#define GET_RISCV_MACRO_FUSION_PRED_DECL
34#include "RISCVGenMacroFusion.inc"
36#define GET_SUBTARGETINFO_HEADER
37#include "RISCVGenSubtargetInfo.inc"
42namespace RISCVTuneInfoTable {
79#define GET_RISCVTuneInfoTable_DECL
80#include "RISCVGenSearchableTables.inc"
99 virtual void anchor();
101 RISCVProcFamilyEnum RISCVProcFamily =
Others;
102 RISCVVRGatherCostModelEnum RISCVVRGatherCostModel =
Quadratic;
104 bool IsLittleEndian =
true;
106#define GET_SUBTARGETINFO_MACRO(ATTRIBUTE, DEFAULT, GETTER) \
107 bool ATTRIBUTE = DEFAULT;
108#include "RISCVGenSubtargetInfo.inc"
110 unsigned XSfmmTE = 0;
112 unsigned RVVVectorBitsMin;
113 unsigned RVVVectorBitsMax;
116 std::bitset<RISCV::NUM_TARGET_REGS> UserReservedRegister;
117 const RISCVTuneInfoTable::RISCVTuneInfo *TuneInfo;
119 RISCVFrameLowering FrameLowering;
120 RISCVInstrInfo InstrInfo;
121 RISCVTargetLowering TLInfo;
133 RISCVSubtarget(
const Triple &TT, StringRef CPU, StringRef TuneCPU,
134 StringRef FS, StringRef ABIName,
unsigned RVVVectorBitsMin,
144 return &FrameLowering;
148 return &InstrInfo.getRegisterInfo();
161 return Align(TuneInfo->PrefFunctionAlignment);
164 return Align(TuneInfo->PrefLoopAlignment);
175#define GET_SUBTARGETINFO_MACRO(ATTRIBUTE, DEFAULT, GETTER) \
176 bool GETTER() const { return ATTRIBUTE; }
177#include "RISCVGenSubtargetInfo.inc"
188 return HasStdExtZfhmin || HasStdExtZhinxmin;
191 return HasStdExtZfhmin || HasStdExtZfbfmin;
195 return HasStdExtZbb || HasVendorXTHeadBb ||
196 (HasVendorXCVbitmanip && !IsRV64);
199 return HasStdExtZbb || (HasVendorXCVbitmanip && !IsRV64);
202 return HasStdExtZbb || (HasVendorXCVbitmanip && !IsRV64);
205 return HasStdExtZbb || HasStdExtZbkb || HasVendorXTHeadBb;
208 return HasStdExtP || ((HasVendorXCVbitmanip || HasVendorXqcibm) && !IsRV64);
211 bool hasBEXTILike()
const {
return HasStdExtZbs || HasVendorXTHeadBs; }
214 return HasStdExtZicond || HasVendorXVentanaCondOps;
219 return (hasConditionalCompressedMoveFusion() && hasStdExtZca()) ||
220 hasShortForwardBranchIALU();
227 return HasStdExtZba || HasVendorXAndesPerf || HasVendorXTHeadBa;
228 return ShAmt <= 31 && HasVendorXqciac;
234 return is64Bit() ? MVT::i64 : MVT::i32;
252 return Align(enableUnalignedScalarMem() ? 1
253 : allowZilsd4ByteAlign() ? 4
263 return VLen == 0 ? ZvlLen : VLen;
267 return VLen == 0 ? 65536 : VLen;
281 if (
auto VLen =
getRealVLen(); VLen &&
X.isScalable()) {
283 X = Quantity::getFixed(
X.getKnownMinValue() * VScale);
295 assert(i.
id() < RISCV::NUM_TARGET_REGS &&
"Register out of range");
296 return UserReservedRegister[i.
id()];
308 return HasStdExtZvfbfmin || HasStdExtZvfbfa;
323 return hasOptimizedNF2SegmentLoadStore();
325 return hasOptimizedNF3SegmentLoadStore();
327 return hasOptimizedNF4SegmentLoadStore();
329 return hasOptimizedNF5SegmentLoadStore();
331 return hasOptimizedNF6SegmentLoadStore();
333 return hasOptimizedNF7SegmentLoadStore();
335 return hasOptimizedNF8SegmentLoadStore();
354 std::unique_ptr<const SelectionDAGTargetInfo>
TSInfo;
396 bool useAA()
const override;
399 return TuneInfo->CacheLineSize;
402 return TuneInfo->PrefetchDistance;
405 unsigned NumStridedMemAccesses,
406 unsigned NumPrefetches,
407 bool HasCall)
const override {
408 return TuneInfo->MinPrefetchStride;
411 return TuneInfo->MaxPrefetchIterationsAhead;
418 return TuneInfo->TailDupAggressiveThreshold;
422 return OptSize ? TuneInfo->MaxStoresPerMemsetOptSize
423 : TuneInfo->MaxStoresPerMemset;
427 return TuneInfo->MaxGluedStoresPerMemcpy;
431 return OptSize ? TuneInfo->MaxStoresPerMemcpyOptSize
432 : TuneInfo->MaxStoresPerMemcpy;
436 return OptSize ? TuneInfo->MaxStoresPerMemmoveOptSize
437 : TuneInfo->MaxStoresPerMemmove;
441 return OptSize ? TuneInfo->MaxLoadsPerMemcmpOptSize
442 : TuneInfo->MaxLoadsPerMemcmp;
446 return TuneInfo->PostRASchedDirection;
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file describes how to lower LLVM calls to machine code calls.
#define LLVM_DEPRECATED(MSG, FIX)
This file describes how to lower LLVM inline asm to machine code INLINEASM.
Interface for Targets to specify which operations they can successfully select and how the others sho...
static const unsigned MaxInterleaveFactor
Maximum vectorization interleave count.
This file declares the targeting of the RegisterBankInfo class for RISC-V.
static cl::opt< unsigned > RVVVectorLMULMax("riscv-v-fixed-length-vector-lmul-max", cl::desc("The maximum LMUL value to use for fixed length vectors. " "Fractional LMUL values are not supported."), cl::init(8), cl::Hidden)
This class provides the information for the target register banks.
RISCVABI::ABI getTargetABI() const
unsigned getMinimumJumpTableEntries() const
RISCVVRGatherCostModelEnum
const LegalizerInfo * getLegalizerInfo() const override
bool isJumpExpensive() const
void overrideSchedPolicy(MachineSchedPolicy &Policy, const SchedRegion &Region) const override
bool enableWritePrefetching() const override
std::unique_ptr< LegalizerInfo > Legalizer
unsigned getMaxLMULForFixedLengthVectors() const
bool hasVInstructionsI64() const
bool isPExtPackedDoubleType(MVT VT) const
unsigned getMaxPrefetchIterationsAhead() const override
bool hasVInstructionsF64() const
unsigned getMaxStoresPerMemcpy(bool OptSize) const
bool hasStdExtDOrZdinx() const
unsigned getMaxLoadsPerMemcmp(bool OptSize) const
bool hasStdExtZfhOrZhinx() const
bool hasShlAdd(int64_t ShAmt) const
bool useDFAforSMS() const override
unsigned getTailDupAggressiveThreshold() const
unsigned getRealMinVLen() const
unsigned getMaxStoresPerMemset(bool OptSize) const
bool useMIPSLoadStorePairs() const
const InlineAsmLowering * getInlineAsmLowering() const override
Quantity expandVScale(Quantity X) const
If the ElementCount or TypeSize X is scalable and VScale (VLEN) is exactly known, returns X converted...
bool useRVVForFixedLengthVectors() const
RISCVVRGatherCostModelEnum getVRGatherCostModel() const
MISched::Direction getPostRASchedDirection() const
std::unique_ptr< InlineAsmLowering > InlineAsmLoweringInfo
bool isPExtPackedType(MVT VT) const
bool isTargetFuchsia() const
bool hasVInstructionsBF16Minimal() const
unsigned getDLenFactor() const
unsigned getMaxStoresPerMemmove(bool OptSize) const
unsigned getMinRVVVectorSizeInBits() const
std::unique_ptr< InstructionSelector > InstSelector
bool hasVInstructionsF16Minimal() const
RISCVSubtarget(const Triple &TT, StringRef CPU, StringRef TuneCPU, StringRef FS, StringRef ABIName, unsigned RVVVectorBitsMin, unsigned RVVVectorLMULMax, const TargetMachine &TM)
unsigned getMaxGluedStoresPerMemcpy() const
bool hasConditionalMoveFusion() const
bool useMIPSCCMovInsn() const
bool hasVInstructionsF16() const
bool hasVInstructionsBF16() const
const RISCVRegisterBankInfo * getRegBankInfo() const override
const CallLowering * getCallLowering() const override
bool enableMachineScheduler() const override
InstructionSelector * getInstructionSelector() const override
unsigned getMaxBuildIntsCost() const
Align getPrefLoopAlignment() const
std::unique_ptr< const SelectionDAGTargetInfo > TSInfo
bool hasVInstructions() const
bool useAA() const override
Enable use of alias analysis during code generation (during MI scheduling, DAGCombine,...
bool isRegisterReservedByUser(Register i) const override
bool hasVInstructionsAnyF() const
std::optional< unsigned > getRealVLen() const
bool isXRaySupported() const override
bool enableMachinePipeliner() const override
bool hasOptimizedSegmentLoadStore(unsigned NF) const
bool useConstantPoolForLargeInts() const
bool isLittleEndian() const
bool hasStdExtCOrZcfOrZce() const
Align getPrefFunctionAlignment() const
~RISCVSubtarget() override
RISCVProcFamilyEnum getProcFamily() const
Returns RISC-V processor family.
unsigned getMaxRVVVectorSizeInBits() const
bool hasStdExtZfhminOrZhinxmin() const
unsigned getRealMaxVLen() const
unsigned getMinPrefetchStride(unsigned NumMemAccesses, unsigned NumStridedMemAccesses, unsigned NumPrefetches, bool HasCall) const override
void ParseSubtargetFeatures(StringRef CPU, StringRef TuneCPU, StringRef FS)
const RISCVRegisterInfo * getRegisterInfo() const override
Align getZilsdAlign() const
std::unique_ptr< RISCVRegisterBankInfo > RegBankInfo
void mirFileLoaded(MachineFunction &MF) const override
const RISCVInstrInfo * getInstrInfo() const override
unsigned getCacheLineSize() const override
std::unique_ptr< CallLowering > CallLoweringInfo
bool hasBEXTILike() const
bool hasStdExtCOrZcd() const
bool hasVInstructionsFullMultiply() const
const RISCVTargetLowering * getTargetLowering() const override
void overridePostRASchedPolicy(MachineSchedPolicy &Policy, const SchedRegion &Region) const override
bool hasVInstructionsF32() const
unsigned getMaxInterleaveFactor() const
bool hasCZEROLike() const
bool enableSubRegLiveness() const override
const SelectionDAGTargetInfo * getSelectionDAGInfo() const override
bool isTargetAndroid() const
bool hasStdExtFOrZfinx() const
bool enablePostRAScheduler() const override
bool hasStdExtZvl() const
bool hasHalfFPLoadStoreMove() const
const RISCVFrameLowering * getFrameLowering() const override
unsigned getPrefetchDistance() const override
Wrapper class representing virtual and physical registers.
constexpr unsigned id() const
Targets can subclass this to parameterize the SelectionDAG lowering and instruction selection process...
Represent a constant reference to a string, i.e.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
static constexpr unsigned RVVBitsPerBlock
This is an optimization pass for GlobalISel generic memory operations.
This struct is a compact representation of a valid (non-zero power of two) alignment.
Define a generic scheduling policy for targets that don't provide their own MachineSchedStrategy.
uint16_t PrefetchDistance
uint8_t PrefLoopAlignment
unsigned MaxStoresPerMemmoveOptSize
unsigned MaxGluedStoresPerMemcpy
unsigned MaxStoresPerMemmove
unsigned MaxLoadsPerMemcmpOptSize
uint8_t PrefFunctionAlignment
unsigned MaxPrefetchIterationsAhead
unsigned TailDupAggressiveThreshold
uint16_t MinPrefetchStride
unsigned MaxLoadsPerMemcmp
unsigned MinimumJumpTableEntries
unsigned MaxStoresPerMemset
unsigned MaxStoresPerMemsetOptSize
unsigned MaxStoresPerMemcpy
unsigned MaxStoresPerMemcpyOptSize
MISched::Direction PostRASchedDirection
A region of an MBB for scheduling.