LLVM 22.0.0git
|
#include "Target/AMDGPU/GCNSubtarget.h"
Public Types | |
enum class | TrapHandlerAbi { NONE = 0x00 , AMDHSA = 0x01 } |
enum class | TrapID { LLVMAMDHSATrap = 0x02 , LLVMAMDHSADebugTrap = 0x03 } |
![]() | |
enum | Generation { INVALID = 0 , R600 = 1 , R700 = 2 , EVERGREEN = 3 , NORTHERN_ISLANDS = 4 , SOUTHERN_ISLANDS = 5 , SEA_ISLANDS = 6 , VOLCANIC_ISLANDS = 7 , GFX9 = 8 , GFX10 = 9 , GFX11 = 10 , GFX12 = 11 } |
Static Public Member Functions | |
static bool | hasHalfRate64Ops (const TargetSubtargetInfo &STI) |
![]() | |
static const AMDGPUSubtarget & | get (const MachineFunction &MF) |
static const AMDGPUSubtarget & | get (const TargetMachine &TM, const Function &F) |
Definition at line 33 of file GCNSubtarget.h.
|
strong |
Enumerator | |
---|---|
NONE | |
AMDHSA |
Definition at line 40 of file GCNSubtarget.h.
|
strong |
Enumerator | |
---|---|
LLVMAMDHSATrap | |
LLVMAMDHSADebugTrap |
Definition at line 45 of file GCNSubtarget.h.
GCNSubtarget::GCNSubtarget | ( | const Triple & | TT, |
StringRef | GPU, | ||
StringRef | FS, | ||
const GCNTargetMachine & | TM | ||
) |
Definition at line 167 of file GCNSubtarget.cpp.
References llvm::AMDGPUSubtarget::EUsPerCU, llvm::AMDGPU::IsaInfo::getEUsPerCU(), llvm::AMDGPU::IsaInfo::getMaxWavesPerEU(), getTargetLowering(), and llvm::AMDGPUSubtarget::MaxWavesPerEU.
|
overridedefault |
|
override |
Definition at line 631 of file GCNSubtarget.cpp.
References llvm::TargetSchedModel::computeOperandLatency(), llvm::SDep::Data, getInstrItineraryData(), llvm::SIInstrInfo::getInstrLatency(), llvm::ilist_node_impl< OptionsT >::getIterator(), llvm::SDep::getKind(), llvm::SDep::getLatency(), llvm::MachineInstr::getParent(), llvm::SDep::getReg(), getRegisterInfo(), llvm::SIInstrInfo::getSchedModel(), I, llvm::MachineBasicBlock::instr_end(), llvm::MachineInstr::isBundle(), llvm::SDep::setLatency(), and TRI.
Diagnose inconsistent subtarget features before attempting to codegen function F
.
Definition at line 158 of file GCNSubtarget.cpp.
References llvm::LLVMContext::diagnose(), and F.
Referenced by llvm::AMDGPUDAGToDAGISel::runOnMachineFunction(), and llvm::AMDGPUInstructionSelector::setupMF().
std::pair< unsigned, unsigned > GCNSubtarget::computeOccupancy | ( | const Function & | F, |
unsigned | LDSSize = 0 , |
||
unsigned | NumSGPRs = 0 , |
||
unsigned | NumVGPRs = 0 |
||
) | const |
Subtarget's minimum/maximum occupancy, in number of waves per EU, that can be achieved when the only function running on a CU is F
, each workgroup uses LDSSize
bytes of LDS, and each wave uses NumSGPRs
SGPRs and NumVGPRs
VGPRs.
The flat workgroup sizes associated to the function are a range, so this returns a range as well.
Note that occupancy can be affected by the scratch allocation as well, but we do not have enough information to compute it.
Definition at line 441 of file GCNSubtarget.cpp.
References F, getDynamicVGPRBlockSize(), llvm::AMDGPU::getDynamicVGPRBlockSize(), getOccupancyWithNumSGPRs(), getOccupancyWithNumVGPRs(), llvm::AMDGPUSubtarget::getOccupancyWithWorkGroupSizes(), and isDynamicVGPREnabled().
|
inline |
Definition at line 747 of file GCNSubtarget.h.
References hasD16LoadStore(), llvm::AMDGPU::IsaInfo::AMDGPUTargetID::isSramEccOnOrAny(), and TargetID.
Referenced by llvm::AMDGPUDAGToDAGISel::matchLoadD16FromBuildVector(), and llvm::AMDGPUDAGToDAGISel::PreprocessISelDAG().
|
inline |
Definition at line 558 of file GCNSubtarget.h.
References DumpCode.
Referenced by llvm::AMDGPUAsmPrinter::runOnMachineFunction().
|
inlineoverride |
Definition at line 1051 of file GCNSubtarget.h.
|
inline |
Definition at line 703 of file GCNSubtarget.h.
References EnableFlatScratch, flatScratchIsArchitected(), and hasFlatScratchInsts().
Referenced by llvm::SIRegisterInfo::buildVGPRSpillLoadStore(), llvm::SIRegisterInfo::eliminateFrameIndex(), getMaxPrivateElementSize(), llvm::SITargetLowering::isLegalAddressingMode(), llvm::SITargetLowering::LowerCall(), llvm::SITargetLowering::LowerFormalArguments(), llvm::SIRegisterInfo::materializeFrameBaseRegister(), and llvm::SIRegisterInfo::needsFrameBaseReg().
|
inlineoverride |
Definition at line 1034 of file GCNSubtarget.h.
|
inline |
Definition at line 1207 of file GCNSubtarget.h.
References EnableSIScheduler.
Referenced by overrideSchedPolicy().
|
inlineoverride |
Definition at line 1040 of file GCNSubtarget.h.
|
inline |
Definition at line 1496 of file GCNSubtarget.h.
References HasArchitectedFlatScratch.
Referenced by enableFlatScratch().
|
inline |
Definition at line 1490 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 1681 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getAddressableNumArchVGPRs().
Referenced by llvm::GCNSchedStage::checkScheduling().
|
inline |
Definition at line 1607 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getAddressableNumSGPRs().
Definition at line 1686 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getAddressableNumVGPRs().
unsigned GCNSubtarget::getBaseMaxNumSGPRs | ( | const Function & | F, |
std::pair< unsigned, unsigned > | WavesPerEU, | ||
unsigned | PreloadedSGPRs, | ||
unsigned | ReservedNumSGPRs | ||
) | const |
Definition at line 458 of file GCNSubtarget.cpp.
References F, llvm::AMDGPU::IsaInfo::FIXED_NUM_SGPRS_FOR_INIT_BUG, getMaxNumSGPRs(), getMinNumSGPRs(), and hasSGPRInitBug().
Referenced by getMaxNumSGPRs().
unsigned GCNSubtarget::getBaseMaxNumVGPRs | ( | const Function & | F, |
std::pair< unsigned, unsigned > | NumVGPRBounds | ||
) | const |
Definition at line 542 of file GCNSubtarget.cpp.
References F, and hasGFX90AInsts().
Referenced by getMaxNumVGPRs().
Definition at line 411 of file GCNSubtarget.cpp.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, HasArchitectedFlatScratch, isXNACKEnabled(), llvm::AMDGPUSubtarget::SEA_ISLANDS, and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
Referenced by getReservedNumSGPRs().
|
inline |
Definition at line 1760 of file GCNSubtarget.h.
References llvm::SIRegisterInfo::getBoolRC(), and getRegisterInfo().
|
inlineoverride |
Definition at line 326 of file GCNSubtarget.h.
Definition at line 197 of file GCNSubtarget.cpp.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore(), llvm::SIInstrInfo::convertToThreeAddress(), llvm::SIInstrInfo::foldImmediate(), llvm::SIInstrInfo::isOperandLegal(), llvm::SIInstrInfo::legalizeOperandsVOP2(), llvm::SIInstrInfo::legalizeOperandsVOP3(), llvm::SIRegisterInfo::needsFrameBaseReg(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1814 of file GCNSubtarget.h.
References DynamicVGPRBlockSize32.
Referenced by computeOccupancy(), and getMaxNumVGPRs().
|
inlineoverride |
Definition at line 312 of file GCNSubtarget.h.
Referenced by llvm::SIRegisterInfo::getFrameRegister(), and llvm::SITargetLowering::LowerDYNAMIC_STACKALLOC().
|
inline |
Definition at line 356 of file GCNSubtarget.h.
References Gen.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingLoad(), llvm::AMDGPUMCExpr::createOccupancy(), flatScratchIsPointer(), getBaseReservedNumSGPRs(), getConstantBusLimit(), llvm::SIInstrInfo::getDefaultRsrcDataFormat(), getMaxWaveScratchSize(), getNSAThreshold(), getOccupancyWithNumSGPRs(), llvm::SIInstrInfo::getScratchRsrcWords23(), getSetRegWaitStates(), llvm::GCNTTIImpl::getShuffleCost(), has12DWordStoreHazard(), hasAddr64(), hasD16Images(), hasD16LoadStore(), hasDenormModeInst(), hasDPPBroadcasts(), hasDPPWavefrontShifts(), hasDsAtomicAsyncBarrierArriveB64PipeBug(), hasDX10ClampMode(), hasExtendedWaitCounts(), hasFlat(), hasFlatLgkmVMemCountInOrder(), hasFlatScratchSVSSwizzleBug(), hasFmaakFmamkF32Insts(), hasFPAtomicToDenormModeHazard(), hasFractBug(), hasGWSAutoReplay(), hasIEEEMode(), hasInstPrefetch(), hasLdsDirect(), hasLdsWaitVMSRC(), hasLegacyGeometry(), hasMad64_32(), hasMed3_16(), hasMergedShaders(), hasMin3Max3_16(), hasMultiDwordFlatScratchAddressing(), hasNoF16PseudoScalarTransInlineConstants(), hasNonNSAEncoding(), hasOnlyRevVALUShifts(), hasPermLane64(), hasPermLaneX16(), hasReadM0LdsDirectHazard(), hasReadM0LdsDmaHazard(), hasReadM0MovRelInterpHazard(), hasReadM0SendMsgHazard(), hasReadVCCZBug(), hasRFEHazards(), hasRrWGMode(), hasScalarAddSub64(), hasScalarCompareEq64(), hasScalarSMulU64(), hasScalarSubwordLoads(), hasSCmpK(), hasScratchBaseForwardingHazard(), hasSignedScratchOffsets(), hasSMRDReadVALUDefHazard(), hasSplitBarriers(), hasUsableDivScaleConditionOutput(), hasUsableDSOffset(), hasVALUMaskWriteHazard(), hasVALUPartialForwardingHazard(), hasVMEMReadSGPRVALUDefHazard(), hasVOP3DPP(), initializeSubtargetDependencies(), llvm::SITargetLowering::isLegalAddressingMode(), ldsRequiresM0Init(), llvm::AMDGPULegalizerInfo::legalizeMul(), llvm::SIInstrInfo::legalizeOperands(), llvm::AMDGPULegalizerInfo::legalizeRsqClampIntrinsic(), llvm::SITargetLowering::LowerFormalArguments(), llvm::SIInstrInfo::moveToVALUImpl(), partialVCCWritesUpdateVCCZ(), privateMemoryResourceIsRangeChecked(), llvm::SIInstrInfo::pseudoToMCOpcode(), llvm::AMDGPU::RegBankLegalizeRules::RegBankLegalizeRules(), llvm::AMDGPUAsmPrinter::runOnMachineFunction(), setRegModeNeedsVNOPs(), shouldClusterStores(), llvm::SITargetLowering::SITargetLowering(), llvm::SIInstrInfo::splitMUBUFOffset(), supportsGetDoorbellID(), supportsMinMaxDenormModes(), supportsWave32(), supportsWGP(), llvm::SIInstrInfo::verifyInstruction(), vmemWriteNeedsExpWaitcnt(), and zeroesHigh16BitsOfDest().
|
inlineoverride |
Definition at line 330 of file GCNSubtarget.h.
|
inlineoverride |
Definition at line 308 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::AddMemOpInit(), llvm::SITargetLowering::AdjustInstrPostInstrSelection(), llvm::SIRegisterInfo::buildSpillLoadStore(), llvm::SITargetLowering::bundleInstWithWaitcnt(), llvm::SIRegisterInfo::eliminateFrameIndex(), llvm::SITargetLowering::emitGWSMemViolTestLoop(), llvm::AMDGPUAsmPrinter::emitInstruction(), llvm::SITargetLowering::EmitInstrWithCustomInserter(), llvm::SIProgramInfo::getFunctionCodeSize(), llvm::SITargetLowering::getPrefLoopAlignment(), llvm::GCNSchedStage::getScheduleMetrics(), llvm::SITargetLowering::insertCopiesSplitCSR(), llvm::SIRegisterInfo::isFrameOffsetLegal(), llvm::SITargetLowering::isLegalFlatAddressingMode(), llvm::AMDGPULegalizerInfo::legalizeTrapHsa(), llvm::SIRegisterInfo::materializeFrameBaseRegister(), llvm::SIRegisterInfo::needsFrameBaseReg(), llvm::SITargetLowering::PerformDAGCombine(), llvm::PhiLoweringHelper::PhiLoweringHelper(), llvm::SITargetLowering::PostISelFolding(), llvm::SIRegisterInfo::resolveFrameIndex(), llvm::SIRegisterInfo::restoreSGPR(), llvm::SIRegisterInfo::spillEmergencySGPR(), llvm::SIRegisterInfo::spillSGPR(), llvm::SITargetLowering::splitKillBlock(), and llvm::SITargetLowering::wrapAddr64Rsrc().
|
inlineoverride |
Definition at line 350 of file GCNSubtarget.h.
References InstrItins.
Referenced by adjustSchedDependency().
|
inlineoverride |
Definition at line 334 of file GCNSubtarget.h.
|
inline |
Return the number of high bits known to be zero for a frame index.
Definition at line 375 of file GCNSubtarget.h.
References llvm::countl_zero(), getMaxWaveScratchSize(), and llvm::AMDGPUSubtarget::getWavefrontSizeLog2().
Referenced by llvm::SITargetLowering::LowerFormalArguments().
|
inline |
Definition at line 379 of file GCNSubtarget.h.
References LDSBankCount.
|
inlineoverride |
Definition at line 338 of file GCNSubtarget.h.
|
inlineoverridevirtual |
Implements llvm::AMDGPUSubtarget.
Definition at line 1776 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMaxFlatWorkGroupSize().
unsigned llvm::GCNSubtarget::getMaxLocalMemSizeWithWaveCount | ( | unsigned | WaveCount, |
const Function & | |||
) | const |
Return the amount of LDS that can be used that will not restrict the occupancy lower than WaveCount.
Definition at line 1722 of file GCNSubtarget.h.
References F, and getMaxNumVGPRs().
unsigned GCNSubtarget::getMaxNumPreloadedSGPRs | ( | ) | const |
Definition at line 512 of file GCNSubtarget.cpp.
Referenced by getMaxNumSGPRs().
F
, or number of SGPRs explicitly requested using "amdgpu-num-sgpr" attribute attached to function F
.Definition at line 537 of file GCNSubtarget.cpp.
References F, getBaseMaxNumSGPRs(), getMaxNumPreloadedSGPRs(), getReservedNumSGPRs(), and llvm::AMDGPUSubtarget::getWavesPerEU().
unsigned GCNSubtarget::getMaxNumSGPRs | ( | const MachineFunction & | MF | ) | const |
MF
, or number of SGPRs explicitly requested using "amdgpu-num-sgpr" attribute attached to function MF
.Definition at line 505 of file GCNSubtarget.cpp.
References F, getBaseMaxNumSGPRs(), llvm::MachineFunction::getFunction(), llvm::MachineFunction::getInfo(), llvm::SIMachineFunctionInfo::getNumPreloadedSGPRs(), getReservedNumSGPRs(), and llvm::SIMachineFunctionInfo::getWavesPerEU().
Definition at line 1619 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMaxNumSGPRs().
Referenced by llvm::GCNSchedStage::checkScheduling(), llvm::SIRegisterInfo::getAlignedHighSGPRForRC(), llvm::SIRegisterInfo::getAllSGPR128(), llvm::SIRegisterInfo::getAllSGPR32(), llvm::SIRegisterInfo::getAllSGPR64(), getBaseMaxNumSGPRs(), llvm::SIRegisterInfo::getRegPressureLimit(), and llvm::SIRegisterInfo::getReservedRegs().
|
inline |
Definition at line 1063 of file GCNSubtarget.h.
References llvm::AMDGPU::getMaxNumUserSGPRs().
Return a pair of maximum numbers of VGPRs and AGPRs that meet the number of waves per execution unit required for the function MF
.
Definition at line 575 of file GCNSubtarget.cpp.
References llvm::alignTo(), assert(), F, llvm::AMDGPU::getIntegerPairAttribute(), getMaxNumVGPRs(), hasGFX90AInsts(), and hasMAIInsts().
Referenced by llvm::SIRegisterInfo::getReservedRegs().
F
, or number of VGPRs explicitly requested using "amdgpu-num-vgpr" attribute attached to function F
.Definition at line 557 of file GCNSubtarget.cpp.
References F, getBaseMaxNumVGPRs(), getDynamicVGPRBlockSize(), llvm::AMDGPU::getDynamicVGPRBlockSize(), getMaxNumVGPRs(), getMinNumVGPRs(), llvm::AMDGPUSubtarget::getWavesPerEU(), and isDynamicVGPREnabled().
unsigned GCNSubtarget::getMaxNumVGPRs | ( | const MachineFunction & | MF | ) | const |
MF
, or number of VGPRs explicitly requested using "amdgpu-num-vgpr" attribute attached to function MF
.Definition at line 570 of file GCNSubtarget.cpp.
References llvm::MachineFunction::getFunction(), and getMaxNumVGPRs().
|
inline |
WavesPerEU
. Definition at line 1700 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMaxNumVGPRs().
Referenced by llvm::SITargetLowering::CanLowerReturn(), llvm::GCNSchedStage::checkScheduling(), getMaxNumAGPRs(), getMaxNumVectorRegs(), getMaxNumVGPRs(), and llvm::SIRegisterInfo::getRegPressureLimit().
Definition at line 383 of file GCNSubtarget.h.
References enableFlatScratch(), and MaxPrivateElementSize.
Referenced by llvm::SITargetLowering::canMergeStoresTo(), llvm::GCNTTIImpl::getLoadStoreVecRegBitWidth(), llvm::SIInstrInfo::getScratchRsrcWords23(), and llvm::GCNTTIImpl::isLegalToVectorizeMemChain().
|
inline |
Definition at line 360 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX11, and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::SIRegisterInfo::eliminateFrameIndex(), and getKnownHighZeroBitsForFrameIndex().
|
inline |
Definition at line 379 of file AMDGPUSubtarget.h.
Referenced by getOccupancyWithNumSGPRs().
|
inlineoverridevirtual |
FlatWorkGroupSize
. Implements llvm::AMDGPUSubtarget.
Definition at line 1766 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMaxWorkGroupsPerCU().
|
inlineoverridevirtual |
Implements llvm::AMDGPUSubtarget.
Definition at line 1771 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMinFlatWorkGroupSize().
Definition at line 1613 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMinNumSGPRs().
Referenced by getBaseMaxNumSGPRs().
|
inline |
WavesPerEU
. Definition at line 1692 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMinNumVGPRs().
Referenced by getMaxNumVGPRs().
|
inlineoverridevirtual |
Implements llvm::AMDGPUSubtarget.
Definition at line 1789 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getMinWavesPerEU().
Definition at line 1177 of file GCNSubtarget.h.
References llvm::AMDGPU::getNSAMaxSize().
Referenced by llvm::AMDGPULegalizerInfo::legalizeBVHIntersectRayIntrinsic(), llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic(), and llvm::SIInstrInfo::verifyInstruction().
unsigned GCNSubtarget::getNSAThreshold | ( | const MachineFunction & | MF | ) | const |
Definition at line 676 of file GCNSubtarget.cpp.
References llvm::Function::getFnAttributeAsParsedInteger(), llvm::MachineFunction::getFunction(), getGeneration(), llvm::AMDGPUSubtarget::GFX12, and NSAThreshold.
Referenced by llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic().
Return the maximum number of waves per SIMD for kernels using SGPRs
SGPRs.
Definition at line 398 of file GCNSubtarget.cpp.
References getGeneration(), getMaxWavesPerEU(), and llvm::AMDGPU::IsaInfo::getOccupancyWithNumSGPRs().
Referenced by computeOccupancy().
unsigned GCNSubtarget::getOccupancyWithNumVGPRs | ( | unsigned | VGPRs, |
unsigned | DynamicVGPRBlockSize | ||
) | const |
Return the maximum number of waves per SIMD for kernels using VGPRs
VGPRs.
Definition at line 404 of file GCNSubtarget.cpp.
References llvm::AMDGPU::IsaInfo::getNumWavesPerEUWithNumVGPRs().
Referenced by computeOccupancy().
|
inlineoverride |
Definition at line 342 of file GCNSubtarget.h.
Referenced by llvm::SIInstrInfo::getInstructionUniformity().
|
inlineoverride |
Definition at line 320 of file GCNSubtarget.h.
References llvm::SIInstrInfo::getRegisterInfo().
Referenced by llvm::SITargetLowering::AdjustInstrPostInstrSelection(), adjustSchedDependency(), llvm::GCNTargetMachine::convertFuncInfoToYAML(), llvm::AMDGPUAsmPrinter::emitInstruction(), llvm::SITargetLowering::finalizeLowering(), getBoolRC(), llvm::SIRegisterInfo::getRegAllocationHints(), llvm::SITargetLowering::getRegClassFor(), llvm::SITargetLowering::getRegisterByName(), llvm::SITargetLowering::insertCopiesSplitCSR(), llvm::SITargetLowering::isEligibleForTailCallOptimization(), llvm::GCNTTIImpl::isInlineAsmSourceOfDivergence(), llvm::SITargetLowering::isSDNodeSourceOfDivergence(), llvm::SITargetLowering::LowerCall(), llvm::SITargetLowering::LowerFormalArguments(), llvm::AMDGPUCallLowering::lowerFormalArgumentsKernel(), llvm::SITargetLowering::LowerReturn(), llvm::SITargetLowering::passSpecialInputs(), llvm::SITargetLowering::requiresUniformRegister(), and llvm::SITargetLowering::SITargetLowering().
F
. Definition at line 432 of file GCNSubtarget.cpp.
References getBaseReservedNumSGPRs(), and hasFlatAddressSpace().
unsigned GCNSubtarget::getReservedNumSGPRs | ( | const MachineFunction & | MF | ) | const |
MF
. Definition at line 427 of file GCNSubtarget.cpp.
References getBaseReservedNumSGPRs(), llvm::MachineFunction::getInfo(), llvm::SIMachineFunctionInfo::getUserSGPRInfo(), and llvm::GCNUserSGPRUsageInfo::hasFlatScratchInit().
Referenced by getMaxNumSGPRs().
|
inline |
Definition at line 1045 of file GCNSubtarget.h.
References ScalarizeGlobal.
|
override |
Definition at line 193 of file GCNSubtarget.cpp.
|
inline |
Number of hazard wait states for s_setreg_b32/s_setreg_imm32_b32.
Definition at line 554 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SEA_ISLANDS.
|
inline |
Definition at line 1592 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getSGPRAllocGranule().
|
inline |
Definition at line 1597 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getSGPREncodingGranule().
|
inline |
Definition at line 1032 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::LowerCall().
|
inline |
Definition at line 346 of file GCNSubtarget.h.
References TargetID.
Referenced by llvm::AMDGPUAsmPrinter::runOnMachineFunction().
|
inlineoverride |
Definition at line 316 of file GCNSubtarget.h.
Referenced by GCNSubtarget(), llvm::AMDGPULegalizerInfo::getImplicitArgPtr(), getTM(), llvm::AMDGPULegalizerInfo::legalizeGlobalValue(), llvm::AMDGPULegalizerInfo::legalizeStackSave(), and llvm::AMDGPULegalizerInfo::legalizeTrapHsaQueuePtr().
|
inline |
Definition at line 1602 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getTotalNumSGPRs().
|
inline |
Definition at line 1675 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getTotalNumVGPRs().
|
inline |
Definition at line 502 of file GCNSubtarget.h.
References AMDHSA, llvm::AMDGPUSubtarget::isAmdHsaOS(), and NONE.
Referenced by llvm::AMDGPULegalizerInfo::legalizeDebugTrap(), and llvm::AMDGPULegalizerInfo::legalizeTrap().
Definition at line 1665 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getVGPRAllocGranule().
|
inline |
Definition at line 1670 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getVGPREncodingGranule().
|
inlineoverridevirtual |
FlatWorkGroupSize
. Implements llvm::AMDGPUSubtarget.
Definition at line 1783 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::getWavesPerEUForWorkGroup().
|
inline |
Definition at line 1233 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS.
|
inline |
Definition at line 1367 of file GCNSubtarget.h.
References Has1_5xVGPRs.
|
inline |
Definition at line 1451 of file GCNSubtarget.h.
References Has64BitLiterals.
Referenced by llvm::AMDGPULegalizerInfo::buildAbsGlobalAddress(), llvm::AMDGPULegalizerInfo::buildPCRelGlobalAddress(), llvm::SIInstrInfo::expandPostRAPseudo(), llvm::SIInstrInfo::getInstSizeInBytes(), llvm::SIInstrInfo::isOperandLegal(), llvm::AMDGPUDAGToDAGISel::Select(), and llvm::AMDGPUDAGToDAGISel::SelectBuildVector().
|
inline |
Definition at line 1153 of file GCNSubtarget.h.
References HasA16.
Referenced by llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1566 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 779 of file GCNSubtarget.h.
References AddNoCarryInsts.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), llvm::SIInstrInfo::getAddNoCarry(), llvm::SIInstrInfo::getVALUOp(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1438 of file GCNSubtarget.h.
References GFX1250Insts.
Referenced by llvm::SIInstrInfo::insertIndirectBranch().
|
inline |
Definition at line 424 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
Referenced by initializeSubtargetDependencies(), llvm::SITargetLowering::isLegalGlobalAddressingMode(), and llvm::SIInstrInfo::legalizeOperands().
|
inline |
Definition at line 1550 of file GCNSubtarget.h.
References HasAddSubU64Insts.
|
inline |
Definition at line 648 of file GCNSubtarget.h.
References HasApertureRegs.
|
inline |
Definition at line 1499 of file GCNSubtarget.h.
References HasArchitectedSGPRs.
Referenced by llvm::SITargetLowering::allocateSystemSGPRs(), llvm::AMDGPULegalizerInfo::legalizeWaveID(), llvm::AMDGPULegalizerInfo::loadInputValue(), and llvm::SITargetLowering::LowerFormalArguments().
|
inline |
Definition at line 1422 of file GCNSubtarget.h.
References HasAshrPkInsts.
|
inline |
Definition at line 926 of file GCNSubtarget.h.
References HasAtomicBufferGlobalPkAddF16Insts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 922 of file GCNSubtarget.h.
References HasAtomicBufferGlobalPkAddF16NoRtnInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 934 of file GCNSubtarget.h.
References HasAtomicBufferPkAddBF16Inst.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 712 of file GCNSubtarget.h.
References GFX10_BEncoding.
|
inline |
Definition at line 1527 of file GCNSubtarget.h.
References HasAtomicCSubNoRtnInsts.
|
inline |
Definition at line 910 of file GCNSubtarget.h.
References HasAtomicDsPkAdd16Insts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 914 of file GCNSubtarget.h.
References HasAtomicFaddNoRtnInsts, and HasAtomicFaddRtnInsts.
Referenced by llvm::SITargetLowering::emitExpandAtomicAddrSpacePredicate().
|
inline |
Definition at line 920 of file GCNSubtarget.h.
References HasAtomicFaddNoRtnInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 918 of file GCNSubtarget.h.
References HasAtomicFaddRtnInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 912 of file GCNSubtarget.h.
References HasAtomicFlatPkAdd16Insts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 902 of file GCNSubtarget.h.
References HasAtomicFMinFMaxF32FlatInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 894 of file GCNSubtarget.h.
References HasAtomicFMinFMaxF32GlobalInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 906 of file GCNSubtarget.h.
References HasAtomicFMinFMaxF64FlatInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 898 of file GCNSubtarget.h.
References HasAtomicFMinFMaxF64GlobalInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 930 of file GCNSubtarget.h.
References HasAtomicGlobalPkAddBF16Inst.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 608 of file GCNSubtarget.h.
References AutoWaitcntBeforeBarrier.
Definition at line 454 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 442 of file GCNSubtarget.h.
Referenced by hasBFM(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 446 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 450 of file GCNSubtarget.h.
References hasBFE().
|
inline |
Definition at line 1418 of file GCNSubtarget.h.
References HasBitOp3Insts.
|
inline |
Definition at line 1464 of file GCNSubtarget.h.
References HasBVHDualAndBVH8Insts.
Referenced by llvm::AMDGPULegalizerInfo::legalizeBVHDualOrBVH8IntersectRayIntrinsic().
|
inline |
Definition at line 480 of file GCNSubtarget.h.
|
inline |
Return true if the target's EXP instruction has the COMPR flag, which affects the meaning of the EN (enable) bits.
Definition at line 1361 of file GCNSubtarget.h.
References GFX11Insts.
|
inline |
Definition at line 1019 of file GCNSubtarget.h.
References HasCUStores.
|
inline |
Definition at line 1523 of file GCNSubtarget.h.
References HasCvtFP8Vop1Bug.
|
inline |
Definition at line 1335 of file GCNSubtarget.h.
References GFX950Insts.
|
inline |
Definition at line 751 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
|
inline |
Definition at line 743 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by d16PreservesUnusedBits().
|
inline |
Definition at line 967 of file GCNSubtarget.h.
References HasDefaultComponentBroadcast.
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic().
|
inline |
Definition at line 965 of file GCNSubtarget.h.
References HasDefaultComponentZero.
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic().
|
inline |
Return true if the target has the S_DELAY_ALU instruction.
Definition at line 1374 of file GCNSubtarget.h.
References GFX11Insts.
|
inline |
Definition at line 572 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
|
inline |
Definition at line 820 of file GCNSubtarget.h.
References HasDLInsts.
Referenced by llvm::SIInstrInfo::getVALUOp(), llvm::SITargetLowering::isFMAFasterThanFMulAndFAdd(), and llvm::SIInstrInfo::moveToVALUImpl().
|
inline |
Definition at line 862 of file GCNSubtarget.h.
References HasDot10Insts.
|
inline |
Definition at line 866 of file GCNSubtarget.h.
References HasDot11Insts.
|
inline |
Definition at line 870 of file GCNSubtarget.h.
References HasDot12Insts.
|
inline |
Definition at line 874 of file GCNSubtarget.h.
References HasDot13Insts.
|
inline |
Definition at line 826 of file GCNSubtarget.h.
References HasDot1Insts.
|
inline |
Definition at line 830 of file GCNSubtarget.h.
References HasDot2Insts.
|
inline |
Definition at line 834 of file GCNSubtarget.h.
References HasDot3Insts.
|
inline |
Definition at line 838 of file GCNSubtarget.h.
References HasDot4Insts.
|
inline |
Definition at line 842 of file GCNSubtarget.h.
References HasDot5Insts.
|
inline |
Definition at line 846 of file GCNSubtarget.h.
References HasDot6Insts.
|
inline |
Definition at line 850 of file GCNSubtarget.h.
References HasDot7Insts.
|
inline |
Definition at line 854 of file GCNSubtarget.h.
References HasDot8Insts.
|
inline |
Definition at line 858 of file GCNSubtarget.h.
References HasDot9Insts.
|
inline |
Definition at line 1302 of file GCNSubtarget.h.
References GFX11Insts, and GFX940Insts.
|
inline |
Definition at line 1120 of file GCNSubtarget.h.
References HasDPALU_DPP.
Referenced by llvm::AMDGPULegalizerInfo::legalizeLaneOp().
|
inline |
Definition at line 1104 of file GCNSubtarget.h.
References HasDPP.
|
inline |
Definition at line 1116 of file GCNSubtarget.h.
References HasDPP8.
|
inline |
Definition at line 1108 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, and HasDPP.
|
inline |
Definition at line 1124 of file GCNSubtarget.h.
References HasDPPSrc1SGPR.
|
inline |
Definition at line 1112 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, and HasDPP.
|
inline |
Definition at line 587 of file GCNSubtarget.h.
References CIInsts.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 1826 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 1299 of file GCNSubtarget.h.
References GFX940Insts.
|
inline |
Definition at line 1238 of file GCNSubtarget.h.
References CIInsts.
|
inline |
Definition at line 1530 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 961 of file GCNSubtarget.h.
References HasEmulatedSystemScopeAtomics.
Referenced by globalMemoryFPAtomicIsLegal(), and llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 720 of file GCNSubtarget.h.
References hasGFX1250Insts(), and hasGFX940Insts().
|
inline |
Definition at line 1145 of file GCNSubtarget.h.
References HasExtendedImageInsts.
|
inline |
Definition at line 1407 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 462 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 458 of file GCNSubtarget.h.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 428 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS.
Referenced by initializeSubtargetDependencies().
|
inline |
Definition at line 670 of file GCNSubtarget.h.
References FlatAddressSpace.
Referenced by getReservedNumSGPRs(), and hasFlatScrRegister().
|
inline |
Definition at line 938 of file GCNSubtarget.h.
References HasFlatAtomicFaddF32Inst.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 942 of file GCNSubtarget.h.
References HasFlatBufferGlobalAtomicFaddF64Inst.
Referenced by llvm::SITargetLowering::emitExpandAtomicAddrSpacePredicate(), and llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 682 of file GCNSubtarget.h.
References FlatGlobalInsts.
Referenced by llvm::SITargetLowering::isLegalGlobalAddressingMode().
|
inline |
Definition at line 1202 of file GCNSubtarget.h.
References FlatGVSMode.
Referenced by llvm::SIInstrInfo::legalizeOperandsFLAT(), and llvm::SIInstrInfo::moveFlatAddrToVGPR().
|
inline |
Definition at line 678 of file GCNSubtarget.h.
References FlatInstOffsets.
Referenced by llvm::SITargetLowering::isLegalFlatAddressingMode(), llvm::SIInstrInfo::isLegalFLATOffset(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 739 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 686 of file GCNSubtarget.h.
References FlatScratchInsts.
Referenced by enableFlatScratch(), and hasFlatScratchSTMode().
|
inline |
Definition at line 693 of file GCNSubtarget.h.
References hasFlatScratchInsts(), hasGFX10_3Insts(), and hasGFX940Insts().
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore(), and llvm::SIRegisterInfo::eliminateFrameIndex().
|
inline |
Definition at line 697 of file GCNSubtarget.h.
References GFX11Insts, and GFX940Insts.
|
inline |
Definition at line 1371 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 674 of file GCNSubtarget.h.
References hasFlatAddressSpace().
Referenced by llvm::SITargetLowering::getRegisterByName().
|
inline |
Definition at line 735 of file GCNSubtarget.h.
References HasFlatSegmentOffsetBug.
Referenced by llvm::SIInstrInfo::isLegalFLATOffset().
|
inline |
Definition at line 484 of file GCNSubtarget.h.
References FMA.
|
inline |
Definition at line 1135 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, and hasGFX940Insts().
|
inline |
Definition at line 1139 of file GCNSubtarget.h.
References hasGFX1250Insts().
Referenced by llvm::SIInstrInfo::convertToThreeAddress().
|
inline |
Definition at line 824 of file GCNSubtarget.h.
References HasFmacF64Inst.
|
inline |
Definition at line 478 of file GCNSubtarget.h.
References HasFmaMixBF16Insts.
Referenced by llvm::SITargetLowering::isFPExtFoldable().
|
inline |
Definition at line 474 of file GCNSubtarget.h.
References HasFmaMixInsts.
Referenced by llvm::SITargetLowering::isFPExtFoldable().
|
inline |
Definition at line 718 of file GCNSubtarget.h.
References hasGFX1250Insts().
|
inline |
Definition at line 404 of file GCNSubtarget.h.
References FP64.
Referenced by initializeSubtargetDependencies().
|
inline |
Definition at line 886 of file GCNSubtarget.h.
References HasFP8ConversionInsts.
|
inline |
Definition at line 888 of file GCNSubtarget.h.
References HasFP8E5M3Insts.
|
inline |
Definition at line 882 of file GCNSubtarget.h.
References HasFP8Insts.
|
inline |
Definition at line 1319 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
|
inline |
Definition at line 438 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), llvm::AMDGPULegalizerInfo::legalizeFFloor(), and llvm::AMDGPULegalizerInfo::legalizeFFREXP().
|
inline |
Definition at line 420 of file GCNSubtarget.h.
References FullRate64Ops.
Referenced by llvm::AMDGPURegisterBankInfo::getInstrMapping(), and llvm::AMDGPULegalizerInfo::legalizeMul().
|
inline |
Definition at line 1155 of file GCNSubtarget.h.
References HasG16.
Referenced by llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1502 of file GCNSubtarget.h.
References HasGDS.
Referenced by llvm::SITargetLowering::isLegalAddressingMode(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1583 of file GCNSubtarget.h.
References GFX1250Insts, and GFX12Insts.
Referenced by llvm::SIInstrInfo::expandPostRAPseudo().
|
inline |
Definition at line 979 of file GCNSubtarget.h.
References HasGetWaveIdInst.
|
inline |
Definition at line 1189 of file GCNSubtarget.h.
References GFX10_3Insts.
Referenced by hasFlatScratchSTMode().
|
inline |
Definition at line 1181 of file GCNSubtarget.h.
References GFX10_AEncoding.
Referenced by llvm::AMDGPULegalizerInfo::legalizeBVHIntersectRayIntrinsic().
|
inline |
Definition at line 1185 of file GCNSubtarget.h.
References GFX10_BEncoding.
|
inline |
Definition at line 1545 of file GCNSubtarget.h.
References GFX1250Insts.
Referenced by hasExportInsts(), hasFmaakFmamkF64Insts(), hasFormattedMUBUFInsts(), hasLdsAtomicAddF64(), hasMTBUFInsts(), hasVINTERPEncoding(), llvm::SIInstrInfo::pseudoToMCOpcode(), and supportsWave64().
|
inline |
Definition at line 1317 of file GCNSubtarget.h.
References GFX90AInsts.
Referenced by llvm::SIRegisterInfo::buildSpillLoadStore(), llvm::GCNSchedStage::checkScheduling(), llvm::SIInstrInfo::copyPhysReg(), getBaseMaxNumVGPRs(), llvm::SIRegisterInfo::getCalleeSavedRegs(), llvm::SIRegisterInfo::getCallPreservedMask(), llvm::SIRegisterInfo::getCrossCopyRegClass(), getMaxNumVectorRegs(), llvm::SITargetLowering::getRegForInlineAsmConstraint(), llvm::SIRegisterInfo::getReservedRegs(), hasLdsAtomicAddF64(), llvm::SIInstrInfo::hasVALU32BitEncoding(), llvm::SIInstrInfo::isLegalRegOperand(), llvm::SIInstrInfo::pseudoToMCOpcode(), llvm::AMDGPUAsmPrinter::runOnMachineFunction(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1380 of file GCNSubtarget.h.
References GFX940Insts.
Referenced by hasExportInsts(), hasFlatScratchSTMode(), hasFmaakFmamkF32Insts(), llvm::SIInstrInfo::isXDL(), and llvm::SIInstrInfo::pseudoToMCOpcode().
|
inline |
Definition at line 1384 of file GCNSubtarget.h.
References GFX950Insts.
Referenced by hasLDSLoadB96_B128(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Definition at line 708 of file GCNSubtarget.h.
References GFX10_BEncoding.
|
inline |
Definition at line 1341 of file GCNSubtarget.h.
References HasGloballyAddressableScratch.
Referenced by llvm::SIInstrInfo::getGenericInstructionUniformity(), llvm::SITargetLowering::isFreeAddrSpaceCast(), llvm::GCNTTIImpl::isSourceOfDivergence(), llvm::AMDGPULegalizerInfo::legalizeAddrSpaceCast(), and llvm::AMDGPULegalizerInfo::legalizeIsAddrSpace().
|
inline |
Definition at line 1505 of file GCNSubtarget.h.
References HasGWS.
|
inline |
Definition at line 766 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::SITargetLowering::EmitInstrWithCustomInserter().
|
inline |
Definition at line 771 of file GCNSubtarget.h.
References CIInsts.
|
inline |
Definition at line 416 of file GCNSubtarget.h.
References HalfRate64Ops.
|
static |
|
inline |
Definition at line 1315 of file GCNSubtarget.h.
References MaxHardClauseLength.
|
inline |
Definition at line 412 of file GCNSubtarget.h.
References FP64.
|
inline |
Definition at line 1536 of file GCNSubtarget.h.
References HasIEEEMinimumMaximumInsts.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1533 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::GCNTTIImpl::fpenvIEEEMode().
|
inline |
Definition at line 1163 of file GCNSubtarget.h.
References HasImageGather4D16Bug.
|
inline |
Definition at line 1141 of file GCNSubtarget.h.
References HasImageInsts.
|
inline |
Definition at line 1161 of file GCNSubtarget.h.
References HasImageStoreD16Bug.
Referenced by llvm::AMDGPULegalizerInfo::handleD16VData().
|
inline |
Definition at line 1275 of file GCNSubtarget.h.
References HasInstFwdPrefetchBug.
|
inline |
Definition at line 1007 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 400 of file GCNSubtarget.h.
References HasIntClamp.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1563 of file GCNSubtarget.h.
References GFX1250Insts.
Referenced by llvm::AMDGPURegisterBankInfo::getInstrMapping(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1517 of file GCNSubtarget.h.
References KernargPreload.
Referenced by llvm::SITargetLowering::LowerFormalArguments(), and needsKernArgPreloadProlog().
|
inline |
Definition at line 727 of file GCNSubtarget.h.
References hasGFX1250Insts(), and hasGFX90AInsts().
|
inline |
Definition at line 1455 of file GCNSubtarget.h.
References HasLdsBarrierArriveAtomic.
|
inline |
Definition at line 1283 of file GCNSubtarget.h.
References HasLdsBranchVmemWARHazard.
|
inline |
Definition at line 1325 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 1095 of file GCNSubtarget.h.
References GFX8Insts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 1096 of file GCNSubtarget.h.
References GFX1250Insts, and GFX90AInsts.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Returns true if the target supports global_load_lds_dwordx3/global_load_lds_dwordx4 or buffer_load_dwordx3/buffer_load_dwordx4 with the lds bit.
Definition at line 1389 of file GCNSubtarget.h.
References hasGFX950Insts().
|
inline |
Definition at line 1271 of file GCNSubtarget.h.
References EnableCuMode, and LDSMisalignedBug.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 1327 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 1514 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 1197 of file GCNSubtarget.h.
References HasLshlAddU64Inst.
|
inline |
Definition at line 796 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SEA_ISLANDS.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), llvm::AMDGPULegalizerInfo::legalizeMul(), and llvm::SITargetLowering::SITargetLowering().
bool GCNSubtarget::hasMadF16 | ( | ) | const |
Definition at line 388 of file GCNSubtarget.cpp.
References llvm::SIInstrInfo::pseudoToMCOpcode().
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), llvm::SITargetLowering::isFMADLegal(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1165 of file GCNSubtarget.h.
References HasMADIntraFwdBug.
|
inline |
Definition at line 1553 of file GCNSubtarget.h.
References HasMadU32Inst.
|
inline |
Definition at line 1560 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 878 of file GCNSubtarget.h.
References HasMAIInsts.
Referenced by llvm::AMDGPU::HSAMD::MetadataStreamerMsgPackV4::getHSAKernelProps(), llvm::SIRegisterInfo::getLargestLegalSuperClass(), getMaxNumVectorRegs(), llvm::SITargetLowering::getRegForInlineAsmConstraint(), llvm::SIRegisterInfo::getReservedRegs(), llvm::SIInstrInfo::getVectorRegSpillRestoreOpcode(), llvm::SIInstrInfo::getVectorRegSpillSaveOpcode(), llvm::SIInstrInfo::isLegalRegOperand(), and llvm::AMDGPUAsmPrinter::runOnMachineFunction().
|
inline |
Definition at line 466 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 948 of file GCNSubtarget.h.
References HasMemoryAtomicFaddF32DenormalSupport.
Referenced by llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 1509 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 1229 of file GCNSubtarget.h.
References HasMFMAInlineLiteralBug.
Referenced by llvm::SIInstrInfo::isImmOperandLegal(), and llvm::SIRegisterInfo::opCanUseInlineConstant().
|
inline |
Definition at line 408 of file GCNSubtarget.h.
References MIMG_R128.
|
inline |
Definition at line 470 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by supportsMin3Max3().
|
inline |
Definition at line 1432 of file GCNSubtarget.h.
References HasMin3Max3PKF16.
Referenced by supportsMin3Max3().
|
inline |
Definition at line 1428 of file GCNSubtarget.h.
References HasMinimum3Maximum3F16.
Referenced by llvm::SITargetLowering::SITargetLowering(), and supportsMin3Max3().
|
inline |
Definition at line 1424 of file GCNSubtarget.h.
References HasMinimum3Maximum3F32.
Referenced by llvm::SITargetLowering::SITargetLowering(), and supportsMin3Max3().
|
inline |
Definition at line 1440 of file GCNSubtarget.h.
References HasMinimum3Maximum3PKF16.
Referenced by llvm::SITargetLowering::SITargetLowering(), and supportsMin3Max3().
|
inline |
Definition at line 1195 of file GCNSubtarget.h.
References GFX1250Insts, and GFX940Insts.
Referenced by llvm::SIInstrInfo::copyPhysReg(), llvm::SIInstrInfo::expandMovDPP64(), and llvm::SIInstrInfo::expandPostRAPseudo().
|
inline |
Definition at line 1071 of file GCNSubtarget.h.
References HasMovrel.
Referenced by llvm::SITargetLowering::shouldExpandVectorDynExt(), and useVGPRIndexMode().
|
inline |
Definition at line 1167 of file GCNSubtarget.h.
References HasMSAALoadDstSelBug.
|
inline |
Definition at line 716 of file GCNSubtarget.h.
References hasGFX1250Insts().
|
inline |
Definition at line 731 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 1223 of file GCNSubtarget.h.
References NegativeScratchOffsetBug.
Referenced by llvm::SIInstrInfo::allowNegativeFlatOffset().
|
inline |
Definition at line 1225 of file GCNSubtarget.h.
References NegativeUnalignedScratchOffsetBug.
Referenced by llvm::SIInstrInfo::isLegalFLATOffset(), and llvm::SIInstrInfo::splitFlatOffset().
|
inline |
Definition at line 999 of file GCNSubtarget.h.
References HasNoDataDepHazard.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Definition at line 1411 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::SIInstrInfo::isOperandLegal().
|
inline |
Definition at line 1173 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 971 of file GCNSubtarget.h.
References HasNoSdstCMPX.
|
inline |
Definition at line 1313 of file GCNSubtarget.h.
References HasNSAClauseBug.
|
inline |
Definition at line 1171 of file GCNSubtarget.h.
References HasNSAEncoding.
Referenced by llvm::AMDGPULegalizerInfo::legalizeBVHIntersectRayIntrinsic(), and llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic().
|
inline |
Definition at line 1309 of file GCNSubtarget.h.
References HasNSAtoVMEMBug.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Return true if the target's EXP instruction supports the NULL export target.
Definition at line 1365 of file GCNSubtarget.h.
References GFX11Insts.
|
inline |
Definition at line 1157 of file GCNSubtarget.h.
References HasOffset3fBug.
Referenced by llvm::AMDGPUAsmPrinter::emitInstruction(), llvm::SIInstrInfo::getInstSizeInBytes(), and llvm::SIInstrInfo::insertBranch().
|
inline |
Definition at line 434 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
Referenced by llvm::SIInstrInfo::moveToVALUImpl().
|
inline |
Definition at line 1126 of file GCNSubtarget.h.
References HasPackedFP32Ops.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), llvm::GCNTTIImpl::getArithmeticInstrCost(), llvm::GCNTTIImpl::getIntrinsicInstrCost(), llvm::GCNTTIImpl::getMaximumVF(), llvm::GCNTTIImpl::getRegisterBitWidth(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1376 of file GCNSubtarget.h.
References HasPackedTID.
Referenced by llvm::SITargetLowering::allocateSpecialEntryInputVGPRs().
|
inline |
Definition at line 1175 of file GCNSubtarget.h.
References HasPartialNSAEncoding.
Referenced by llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1420 of file GCNSubtarget.h.
References HasPermlane16Swap.
|
inline |
Definition at line 1421 of file GCNSubtarget.h.
References HasPermlane32Swap.
|
inline |
Definition at line 1102 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 1099 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
|
inline |
Definition at line 1569 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 890 of file GCNSubtarget.h.
References HasPkFmacF16Inst.
|
inline |
Definition at line 1572 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1131 of file GCNSubtarget.h.
References GFX90AInsts.
Referenced by llvm::SIInstrInfo::copyPhysReg(), llvm::SIInstrInfo::expandPostRAPseudo(), llvm::AMDGPUDAGToDAGISel::SelectVectorShuffle(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1453 of file GCNSubtarget.h.
References HasPointSampleAccel.
|
inline |
Definition at line 1011 of file GCNSubtarget.h.
References GFX12Insts.
Referenced by llvm::GCNTTIImpl::getPrefetchDistance().
|
inline |
Definition at line 1169 of file GCNSubtarget.h.
References HasPrivEnabledTrap2NopBug.
Referenced by llvm::SITargetLowering::EmitInstrWithCustomInserter(), and llvm::AMDGPULegalizerInfo::legalizeTrapHsa().
|
inline |
Definition at line 1462 of file GCNSubtarget.h.
References HasPrngInst.
|
inline |
Definition at line 1397 of file GCNSubtarget.h.
References HasPseudoScalarTrans.
Referenced by llvm::AMDGPURegisterBankInfo::getInstrMapping().
|
inline |
Definition at line 1149 of file GCNSubtarget.h.
References HasR128A16.
Referenced by llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1255 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Definition at line 1251 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Definition at line 1242 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Definition at line 1246 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX9, and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
Referenced by llvm::GCNHazardRecognizer::getHazardType(), and llvm::GCNHazardRecognizer::PreEmitNoopsCommon().
|
inline |
Extra wait hazard is needed in some cases before s_cbranch_vccnz/s_cbranch_vccz.
Definition at line 528 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SEA_ISLANDS.
|
inline |
Definition at line 646 of file GCNSubtarget.h.
References RelaxedBufferOOBMode.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 1401 of file GCNSubtarget.h.
References HasRequiredExportPriority.
|
inline |
Definition at line 1399 of file GCNSubtarget.h.
References HasRestrictedSOffset.
Referenced by selectSOffset(), and llvm::SIInstrInfo::splitMUBUFOffset().
|
inline |
Definition at line 549 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
|
inline |
Definition at line 1539 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 1017 of file GCNSubtarget.h.
References HasSafeCUPrefetch.
|
inline |
Definition at line 1015 of file GCNSubtarget.h.
References HasSafeSmemPrefetch.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingImpl(), llvm::SITargetLowering::lowerPREFETCH(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1395 of file GCNSubtarget.h.
References HasSALUFloatInsts.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingImpl(), llvm::AMDGPURegisterBankInfo::getInstrMapping(), and llvm::AMDGPU::RegBankLegalizeRules::RegBankLegalizeRules().
|
inline |
Definition at line 783 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), and llvm::SITargetLowering::EmitInstrWithCustomInserter().
|
inline |
Definition at line 1091 of file GCNSubtarget.h.
References HasScalarAtomics.
|
inline |
Definition at line 1081 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
Referenced by llvm::SIInstrInfo::copyPhysReg(), and llvm::AMDGPURegisterBankInfo::getInstrMapping().
|
inline |
Definition at line 1085 of file GCNSubtarget.h.
References HasScalarDwordx3Loads.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingLoad(), and llvm::AMDGPULegalizerInfo::legalizeSBufferLoad().
|
inline |
Definition at line 699 of file GCNSubtarget.h.
References ScalarFlatScratchInsts.
|
inline |
Definition at line 496 of file GCNSubtarget.h.
References GFX9Insts.
Referenced by llvm::AMDGPURegisterBankInfo::getInstrMapping().
|
inline |
Definition at line 492 of file GCNSubtarget.h.
References GFX9Insts.
|
inline |
Definition at line 785 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::AMDGPULegalizerInfo::AMDGPULegalizerInfo(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1087 of file GCNSubtarget.h.
References HasScalarStores.
|
inline |
Definition at line 500 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
Referenced by llvm::SITargetLowering::isLegalAddressingMode(), llvm::AMDGPURegisterBankInfo::isScalarLoadLegal(), llvm::AMDGPULegalizerInfo::legalizeSBufferLoad(), llvm::AMDGPU::RegBankLegalizeRules::RegBankLegalizeRules(), and llvm::SITargetLowering::ReplaceNodeResults().
|
inline |
Definition at line 1200 of file GCNSubtarget.h.
References GFX1250Insts.
Referenced by llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1022 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 1832 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX12, and GFX1250Insts.
|
inline |
Definition at line 812 of file GCNSubtarget.h.
References HasSDWAMac.
|
inline |
Definition at line 800 of file GCNSubtarget.h.
References HasSDWAOmod.
Referenced by llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 816 of file GCNSubtarget.h.
References HasSDWAOutModsVOPC.
Referenced by llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 804 of file GCNSubtarget.h.
References HasSDWAScalar.
Referenced by llvm::SIInstrInfo::copyPhysReg(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 808 of file GCNSubtarget.h.
References HasSDWASdst.
Referenced by llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1578 of file GCNSubtarget.h.
References HasSetPrioIncWgInst.
|
inline |
Definition at line 1575 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1215 of file GCNSubtarget.h.
References SGPRInitBug.
Referenced by getBaseMaxNumSGPRs().
|
inline |
Definition at line 991 of file GCNSubtarget.h.
References HasShaderCyclesHiLoRegisters.
Referenced by llvm::SITargetLowering::EmitInstrWithCustomInserter().
|
inline |
Definition at line 987 of file GCNSubtarget.h.
References HasShaderCyclesRegister.
|
inline |
Definition at line 1289 of file GCNSubtarget.h.
References GFX90AInsts, and GFX940Insts.
|
inline |
Definition at line 1205 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1543 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 1067 of file GCNSubtarget.h.
References HasSMemRealTime.
Referenced by llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 983 of file GCNSubtarget.h.
References HasSMemTimeInst.
|
inline |
Definition at line 1267 of file GCNSubtarget.h.
References HasSMEMtoVectorWriteHazard.
|
inline |
A read of an SGPR by SMRD instruction requires 4 wait states when the SGPR was written by a VALU instruction.
Definition at line 539 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS.
|
inline |
Return true if the target has the S_PACK_HL_B32_B16 instruction.
Definition at line 1357 of file GCNSubtarget.h.
References GFX11Insts.
|
inline |
Definition at line 1520 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX12.
|
inline |
Definition at line 488 of file GCNSubtarget.h.
References GFX9Insts.
|
inline |
Definition at line 1434 of file GCNSubtarget.h.
References HasTanhInsts.
|
inline |
Definition at line 1436 of file GCNSubtarget.h.
References HasTensorCvtLutInsts.
|
inline |
Definition at line 1295 of file GCNSubtarget.h.
References GFX940Insts.
|
inline |
Definition at line 1444 of file GCNSubtarget.h.
References HasTransposeLoadF4F6Insts.
|
inline |
Definition at line 642 of file GCNSubtarget.h.
References UnalignedAccessMode.
|
inline |
Definition at line 618 of file GCNSubtarget.h.
References UnalignedBufferAccess.
|
inline |
Definition at line 622 of file GCNSubtarget.h.
References UnalignedAccessMode, and UnalignedBufferAccess.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 626 of file GCNSubtarget.h.
References UnalignedDSAccess.
|
inline |
Definition at line 630 of file GCNSubtarget.h.
References UnalignedAccessMode, and UnalignedDSAccess.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 634 of file GCNSubtarget.h.
References UnalignedScratchAccess.
|
inline |
Definition at line 638 of file GCNSubtarget.h.
References UnalignedAccessMode, and UnalignedScratchAccess.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl(), and llvm::GCNTTIImpl::isLegalToVectorizeMemChain().
|
inline |
Definition at line 787 of file GCNSubtarget.h.
References HasUnpackedD16VMem.
Referenced by llvm::SITargetLowering::AddMemOpInit(), llvm::AMDGPURegisterBankInfo::handleD16VData(), llvm::AMDGPULegalizerInfo::handleD16VData(), llvm::AMDGPULegalizerInfo::legalizeBufferLoad(), llvm::AMDGPULegalizerInfo::legalizeImageIntrinsic(), llvm::SIInstrInfo::pseudoToMCOpcode(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Condition output from div_scale is usable.
Definition at line 522 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS.
Referenced by llvm::GCNTTIImpl::getArithmeticInstrCost(), and llvm::AMDGPULegalizerInfo::legalizeFDIV64().
|
inline |
True if the offset field of DS instructions works as expected.
On SI, the offset uses a 16-bit adder and does not always wrap properly.
Definition at line 513 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SEA_ISLANDS.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 1219 of file GCNSubtarget.h.
References isWave32(), and UserSGPRInit16Bug.
Referenced by llvm::SITargetLowering::allocateSystemSGPRs().
|
inline |
Definition at line 1345 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
Referenced by llvm::SIInstrInfo::insertIndirectBranch().
|
inline |
Definition at line 1329 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 1347 of file GCNSubtarget.h.
References GFX1250Insts, and GFX12Insts.
Referenced by llvm::SIInstrInfo::insertIndirectBranch().
|
inline |
Definition at line 1333 of file GCNSubtarget.h.
References HasVALUTransUseHazard.
|
inline |
Definition at line 1279 of file GCNSubtarget.h.
References HasVcmpxExecWARHazard.
|
inline |
Definition at line 1259 of file GCNSubtarget.h.
References HasVcmpxPermlaneHazard.
|
inline |
Definition at line 1305 of file GCNSubtarget.h.
References GFX940Insts.
|
inline |
Definition at line 1556 of file GCNSubtarget.h.
References GFX1250Insts.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingImpl(), llvm::AMDGPURegisterBankInfo::getInstrMapping(), llvm::AMDGPULegalizerInfo::legalizeMul(), llvm::SIInstrInfo::moveToVALUImpl(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
Definition at line 1075 of file GCNSubtarget.h.
References HasVGPRIndexMode.
Referenced by useVGPRIndexMode().
|
inline |
Definition at line 724 of file GCNSubtarget.h.
References GFX11Insts, and hasGFX1250Insts().
|
inline |
Definition at line 1013 of file GCNSubtarget.h.
References HasVmemPrefInsts.
Referenced by llvm::AMDGPURegisterBankInfo::applyMappingImpl(), llvm::SITargetLowering::lowerPREFETCH(), and llvm::SITargetLowering::SITargetLowering().
|
inline |
A read of an SGPR by a VMEM instruction requires 5 wait states when the SGPR was written by a VALU Instruction.
Definition at line 545 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
|
inline |
Definition at line 1393 of file GCNSubtarget.h.
References HasVMemToLDSLoad.
|
inline |
Definition at line 1263 of file GCNSubtarget.h.
References HasVMEMtoScalarWriteHazard.
|
inline |
Definition at line 1403 of file GCNSubtarget.h.
References HasVmemWriteVgprInOrder.
|
inline |
Definition at line 1323 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 995 of file GCNSubtarget.h.
References HasVOP3Literal.
Referenced by llvm::SIInstrInfo::convertToThreeAddress(), llvm::SIRegisterInfo::eliminateFrameIndex(), llvm::SIRegisterInfo::isFrameOffsetLegal(), llvm::SIInstrInfo::isImmOperandLegal(), llvm::SIInstrInfo::isOperandLegal(), llvm::SIInstrInfo::legalizeOperandsVOP3(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1547 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1369 of file GCNSubtarget.h.
References HasVOPDInsts.
|
inline |
Definition at line 975 of file GCNSubtarget.h.
References HasVscnt.
|
inline |
Definition at line 1448 of file GCNSubtarget.h.
References HasWaitXcnt.
|
inline |
Definition at line 1416 of file GCNSubtarget.h.
References HasXF32Insts.
|
inline |
Have v_trunc_f64, v_ceil_f64, v_rndne_f64.
Definition at line 592 of file GCNSubtarget.h.
References CIInsts.
Referenced by llvm::SITargetLowering::SITargetLowering().
GCNSubtarget & GCNSubtarget::initializeSubtargetDependencies | ( | const Triple & | TT, |
StringRef | GPU, | ||
StringRef | FS | ||
) |
Definition at line 57 of file GCNSubtarget.cpp.
References llvm::AMDGPUSubtarget::AddressableLocalMemorySize, llvm::Triple::AMDHSA, assert(), llvm::dbgs(), FlatForGlobal, Gen, getGeneration(), llvm::AMDGPU::IsaInfo::getLocalMemorySize(), llvm::AMDGPU::IsaInfo::AMDGPUTargetID::getSramEccSetting(), llvm::AMDGPUSubtarget::getWavefrontSizeLog2(), llvm::AMDGPU::IsaInfo::AMDGPUTargetID::getXnackSetting(), llvm::AMDGPUSubtarget::GFX10, llvm::AMDGPUSubtarget::GFX9, hasAddr64(), hasFlat(), llvm::AMDGPUSubtarget::HasFminFmaxLegacy, hasFP64(), llvm::AMDGPUSubtarget::HasSMulHi, llvm::AMDGPUSubtarget::INVALID, llvm::AMDGPUSubtarget::isAmdHsaOS(), LDSBankCount, LLVM_DEBUG, llvm::AMDGPUSubtarget::LocalMemorySize, MaxPrivateElementSize, ParseSubtargetFeatures(), llvm::AMDGPUSubtarget::SEA_ISLANDS, llvm::AMDGPU::IsaInfo::AMDGPUTargetID::setTargetIDFromFeaturesString(), llvm::AMDGPUSubtarget::SOUTHERN_ISLANDS, TargetID, llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS, and llvm::AMDGPUSubtarget::WavefrontSizeLog2.
|
inline |
Definition at line 664 of file GCNSubtarget.h.
References EnableCuMode.
|
inline |
Definition at line 1813 of file GCNSubtarget.h.
References DynamicVGPR.
Referenced by computeOccupancy(), and getMaxNumVGPRs().
Definition at line 792 of file GCNSubtarget.h.
References F, llvm::AMDGPUSubtarget::isMesa3DOS(), and llvm::AMDGPU::isShader().
|
inline |
Definition at line 668 of file GCNSubtarget.h.
References EnablePreciseMemory.
|
inline |
Definition at line 660 of file GCNSubtarget.h.
References EnableTgSplit.
|
inline |
Definition at line 652 of file GCNSubtarget.h.
References TrapHandler.
Referenced by llvm::AMDGPULegalizerInfo::legalizeDebugTrap(), and llvm::AMDGPULegalizerInfo::legalizeTrap().
|
inline |
Definition at line 1744 of file GCNSubtarget.h.
References llvm::AMDGPUSubtarget::getWavefrontSize().
Referenced by llvm::SIInstrInfo::createPHISourceCopy(), llvm::AMDGPURegisterBankInfo::executeInWaterfallLoop(), llvm::SIInstrInfo::expandPostRAPseudo(), llvm::SIInstrInfo::fixImplicitOperands(), hasUserSGPRInit16Bug(), llvm::SIInstrInfo::insertVectorSelect(), llvm::GCNTTIImpl::instCombineIntrinsic(), llvm::SIInstrInfo::isWave32(), llvm::SITargetLowering::LowerCall(), mirFileLoaded(), llvm::SIInstrInfo::moveToVALUImpl(), and llvm::PhiLoweringHelper::PhiLoweringHelper().
|
inline |
Definition at line 1748 of file GCNSubtarget.h.
References llvm::AMDGPUSubtarget::getWavefrontSize().
Referenced by llvm::SITargetLowering::getRegClassFor(), llvm::SIInstrInfo::getScratchRsrcWords23(), llvm::SIInstrInfo::insertIndirectBranch(), and llvm::AMDGPULegalizerInfo::legalizeAddrSpaceCast().
|
inline |
Returns if the wavesize of this subtarget is known reliable.
This is false only for the a default target-cpu that does not have an explicit +wavefrontsize target feature.
Definition at line 1755 of file GCNSubtarget.h.
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic().
|
inline |
Definition at line 656 of file GCNSubtarget.h.
References llvm::AMDGPU::IsaInfo::AMDGPUTargetID::isXnackOnOrAny(), and TargetID.
Referenced by getBaseReservedNumSGPRs(), and needsConstrainedOpcode().
|
inline |
Return if most LDS instructions have an m0 use that require m0 to be initialized.
Definition at line 757 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 1211 of file GCNSubtarget.h.
References EnableLoadStoreOpt.
|
inline |
Definition at line 1460 of file GCNSubtarget.h.
References MaxHardClauseLength.
|
override |
Definition at line 377 of file GCNSubtarget.cpp.
References llvm::SIInstrInfo::fixImplicitOperands(), isWave32(), MBB, and MI.
|
inline |
Return if operations acting on VGPR tuples require even alignment.
Definition at line 1354 of file GCNSubtarget.h.
References RequiresAlignVGPR.
Referenced by llvm::SIInstrInfo::enforceOperandRCAlignment(), llvm::SIRegisterInfo::getAGPRClassForBitWidth(), llvm::SIRegisterInfo::getProperlyAlignedRC(), llvm::SIRegisterInfo::getVectorSuperClassForBitWidth(), llvm::SIRegisterInfo::getVGPR64Class(), llvm::SIRegisterInfo::getVGPRClassForBitWidth(), llvm::SIRegisterInfo::isProperlyAlignedRC(), and llvm::SIInstrInfo::verifyInstruction().
|
inline |
Definition at line 1587 of file GCNSubtarget.h.
References GFX1250Insts, and hasKernargPreload().
|
override |
Definition at line 340 of file GCNSubtarget.cpp.
References llvm::dbgs(), F, llvm::Attribute::getValueAsString(), if(), llvm::Attribute::isValid(), LLVM_DEBUG, llvm::MachineSchedPolicy::OnlyBottomUp, and llvm::MachineSchedPolicy::OnlyTopDown.
|
override |
Definition at line 323 of file GCNSubtarget.cpp.
References enableSIScheduler(), llvm::MachineSchedPolicy::OnlyBottomUp, llvm::MachineSchedPolicy::OnlyTopDown, llvm::MachineSchedPolicy::ShouldTrackLaneMasks, and llvm::MachineSchedPolicy::ShouldTrackPressure.
Referenced by initializeSubtargetDependencies().
|
inline |
Writes to VCC_LO/VCC_HI update the VCCZ flag.
Definition at line 533 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
|
inline |
Definition at line 598 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
|
inline |
Definition at line 1337 of file GCNSubtarget.h.
References RequiresCOV6.
|
inlineoverride |
Definition at line 1818 of file GCNSubtarget.h.
|
inline |
Definition at line 1807 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1811 of file GCNSubtarget.h.
References GFX1250Insts.
|
inline |
Definition at line 1349 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX12, and GFX1250Insts.
|
inline |
Definition at line 1044 of file GCNSubtarget.h.
References ScalarizeGlobal.
|
inline |
Definition at line 1799 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX11.
|
inline |
Definition at line 955 of file GCNSubtarget.h.
References HasAgentScopeFineGrainedRemoteMemoryAtomics.
Referenced by globalMemoryFPAtomicIsLegal(), and llvm::SITargetLowering::shouldExpandAtomicRMWInIR().
|
inline |
Definition at line 614 of file GCNSubtarget.h.
References BackOffBarrier.
|
inline |
Definition at line 506 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::AMDGPULegalizerInfo::legalizeTrap().
|
inline |
Definition at line 567 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX9.
Referenced by llvm::SITargetLowering::isCanonicalized().
|
inline |
Definition at line 1740 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::GFX10.
|
inline |
Definition at line 1742 of file GCNSubtarget.h.
References hasGFX1250Insts().
|
inline |
Definition at line 394 of file GCNSubtarget.h.
References getGeneration(), llvm::AMDGPUSubtarget::GFX10, and GFX1250Insts.
Referenced by llvm::AMDGPU::HSAMD::MetadataStreamerMsgPackV4::getHSAKernelProps().
|
inline |
Definition at line 517 of file GCNSubtarget.h.
References EnableUnsafeDSOffsetFolding.
|
override |
Definition at line 396 of file GCNSubtarget.cpp.
References UseAA.
|
inline |
Definition at line 582 of file GCNSubtarget.h.
References CIInsts, and EnableDS128.
Referenced by llvm::SITargetLowering::allowsMisalignedMemoryAccessesImpl().
|
inline |
Definition at line 576 of file GCNSubtarget.h.
References FlatForGlobal.
Referenced by llvm::AMDGPURegisterBankInfo::getInstrMappingForLoad(), llvm::AMDGPURegisterBankInfo::getValueMappingForPtr(), and llvm::SITargetLowering::isLegalGlobalAddressingMode().
|
inline |
Definition at line 604 of file GCNSubtarget.h.
References EnablePRTStrictNull.
Referenced by llvm::SITargetLowering::AddMemOpInit().
|
inline |
Definition at line 1339 of file GCNSubtarget.h.
References UseBlockVGPROpsForCSR.
bool GCNSubtarget::useVGPRIndexMode | ( | ) | const |
Definition at line 392 of file GCNSubtarget.cpp.
References EnableVGPRIndexMode, hasMovrel(), and hasVGPRIndexMode().
Referenced by llvm::SIInstrInfo::expandPostRAPseudo(), and llvm::SITargetLowering::shouldExpandVectorDynExt().
|
inline |
Definition at line 1003 of file GCNSubtarget.h.
References getGeneration(), and llvm::AMDGPUSubtarget::SEA_ISLANDS.
Returns if the result of this instruction with a 16-bit result returned in a 32-bit register implicitly zeroes the high 16-bits, rather than preserve the original value.
This list was mostly derived from experimentation.
Definition at line 225 of file GCNSubtarget.cpp.
References getGeneration(), llvm::AMDGPUSubtarget::GFX9, and llvm::AMDGPUSubtarget::VOLCANIC_ISLANDS.
|
protected |
Definition at line 227 of file GCNSubtarget.h.
Referenced by hasAddNoCarry().
|
protected |
Definition at line 77 of file GCNSubtarget.h.
Referenced by hasAutoWaitcntBeforeBarrier().
|
protected |
Definition at line 78 of file GCNSubtarget.h.
Referenced by supportsBackOffBarrier().
|
protected |
Definition at line 107 of file GCNSubtarget.h.
Referenced by hasDS96AndDS128(), hasDwordx3LoadStores(), hasGWSSemaReleaseAll(), haveRoundOpsF64(), and useDS128().
|
protected |
Definition at line 101 of file GCNSubtarget.h.
Referenced by dumpCode().
|
protected |
Definition at line 198 of file GCNSubtarget.h.
Referenced by isDynamicVGPREnabled().
|
protected |
Definition at line 199 of file GCNSubtarget.h.
Referenced by getDynamicVGPRBlockSize().
|
protected |
Definition at line 91 of file GCNSubtarget.h.
Referenced by hasLDSMisalignedBug(), and isCuModeEnabled().
|
protected |
Definition at line 99 of file GCNSubtarget.h.
Referenced by useDS128().
|
protected |
Definition at line 223 of file GCNSubtarget.h.
Referenced by enableFlatScratch().
|
protected |
Definition at line 96 of file GCNSubtarget.h.
Referenced by loadStoreOptEnabled().
|
protected |
Definition at line 93 of file GCNSubtarget.h.
Referenced by isPreciseMemoryEnabled().
|
protected |
Definition at line 100 of file GCNSubtarget.h.
Referenced by usePRTStrictNull().
|
protected |
Definition at line 98 of file GCNSubtarget.h.
Referenced by enableSIScheduler().
|
protected |
Definition at line 205 of file GCNSubtarget.h.
|
protected |
Definition at line 90 of file GCNSubtarget.h.
Referenced by isTgSplitEnabled().
|
protected |
Definition at line 97 of file GCNSubtarget.h.
Referenced by unsafeDSOffsetFoldingEnabled().
|
protected |
Definition at line 88 of file GCNSubtarget.h.
|
protected |
Definition at line 71 of file GCNSubtarget.h.
|
protected |
Definition at line 289 of file GCNSubtarget.h.
|
protected |
Definition at line 216 of file GCNSubtarget.h.
Referenced by hasFlatAddressSpace().
|
protected |
Definition at line 76 of file GCNSubtarget.h.
Referenced by initializeSubtargetDependencies(), and useFlatForGlobal().
|
protected |
Definition at line 218 of file GCNSubtarget.h.
Referenced by hasFlatGlobalInsts().
|
protected |
Definition at line 220 of file GCNSubtarget.h.
Referenced by hasFlatGVSMode().
|
protected |
Definition at line 217 of file GCNSubtarget.h.
Referenced by hasFlatInstOffsets().
|
protected |
Definition at line 219 of file GCNSubtarget.h.
Referenced by hasFlatScratchInsts().
|
protected |
Definition at line 105 of file GCNSubtarget.h.
Referenced by hasFMA().
|
protected |
Definition at line 104 of file GCNSubtarget.h.
Referenced by hasFP64(), and hasHWFP64().
|
protected |
Definition at line 73 of file GCNSubtarget.h.
Referenced by hasFullRate64Ops().
Definition at line 65 of file GCNSubtarget.h.
Referenced by getGeneration(), and initializeSubtargetDependencies().
|
protected |
Definition at line 117 of file GCNSubtarget.h.
Referenced by hasGFX10_3Insts().
|
protected |
Definition at line 149 of file GCNSubtarget.h.
Referenced by hasGFX10_AEncoding().
|
protected |
Definition at line 150 of file GCNSubtarget.h.
Referenced by hasAtomicCSub(), hasGFX10_BEncoding(), and hasGlobalAddTidInsts().
|
protected |
Definition at line 113 of file GCNSubtarget.h.
|
protected |
Definition at line 114 of file GCNSubtarget.h.
Referenced by hasCompressedExport(), hasDelayAlu(), hasDOTOpSelHazard(), hasFlatScratchSVSMode(), hasNullExportTarget(), hasSPackHL(), and hasVINTERPEncoding().
|
protected |
Definition at line 116 of file GCNSubtarget.h.
Referenced by hasAddMinMaxInsts(), hasAddPC64Inst(), hasGetPCZeroExtension(), hasGFX1250Insts(), hasIntMinMax64(), hasLDSFPAtomicAddF64(), hasMadU64U32NoCarry(), hasMovB64(), hasPkAddMinMaxInsts(), hasPkMinMax3Insts(), hasScaleOffset(), hasScratchBaseForwardingHazard(), hasSGetShaderCyclesInst(), hasSignedGVSOffset(), hasVALUReadSGPRHazard(), hasVectorMulU64(), hasVOPD3(), needsKernArgPreloadProlog(), requiresNopBeforeDeallocVGPRs(), requiresWaitIdleBeforeGetReg(), setRegModeNeedsVNOPs(), and supportsWGP().
|
protected |
Definition at line 115 of file GCNSubtarget.h.
Referenced by hasGetPCZeroExtension(), hasPrefetch(), and hasVALUReadSGPRHazard().
|
protected |
Definition at line 118 of file GCNSubtarget.h.
|
protected |
Definition at line 108 of file GCNSubtarget.h.
Referenced by hasLDSFPAtomicAddF32().
|
protected |
Definition at line 110 of file GCNSubtarget.h.
Referenced by hasGFX90AInsts(), hasLDSFPAtomicAddF64(), hasPkMovB32(), and hasShift64HighRegBug().
|
protected |
Definition at line 111 of file GCNSubtarget.h.
Referenced by hasDOTOpSelHazard(), hasDstSelForwardingHazard(), hasFlatScratchSVSMode(), hasGFX940Insts(), hasMovB64(), hasShift64HighRegBug(), hasTransForwardingHazard(), and hasVDecCoExecHazard().
|
protected |
Definition at line 112 of file GCNSubtarget.h.
Referenced by hasCvtScaleForwardingHazard(), and hasGFX950Insts().
|
protected |
Definition at line 109 of file GCNSubtarget.h.
Referenced by hasScalarMulHiInsts(), hasScalarPackInsts(), and hasSwap().
|
protected |
Definition at line 72 of file GCNSubtarget.h.
Referenced by hasHalfRate64Ops().
|
protected |
Definition at line 265 of file GCNSubtarget.h.
Referenced by has1_5xVGPRs().
|
protected |
Definition at line 238 of file GCNSubtarget.h.
Referenced by has64BitLiterals().
|
protected |
Definition at line 145 of file GCNSubtarget.h.
Referenced by hasA16().
|
protected |
Definition at line 278 of file GCNSubtarget.h.
Referenced by hasAddSubU64Insts().
|
protected |
Definition at line 189 of file GCNSubtarget.h.
Referenced by supportsAgentScopeFineGrainedRemoteMemoryAtomics().
|
protected |
Definition at line 82 of file GCNSubtarget.h.
Referenced by hasApertureRegs().
|
protected |
Definition at line 222 of file GCNSubtarget.h.
Referenced by flatScratchIsArchitected(), and getBaseReservedNumSGPRs().
|
protected |
Definition at line 224 of file GCNSubtarget.h.
Referenced by hasArchitectedSGPRs().
|
protected |
Definition at line 271 of file GCNSubtarget.h.
Referenced by hasAshrPkInsts().
|
protected |
Definition at line 182 of file GCNSubtarget.h.
Referenced by hasAtomicBufferGlobalPkAddF16Insts().
|
protected |
Definition at line 181 of file GCNSubtarget.h.
Referenced by hasAtomicBufferGlobalPkAddF16NoRtnInsts().
|
protected |
Definition at line 185 of file GCNSubtarget.h.
Referenced by hasAtomicBufferPkAddBF16Inst().
|
protected |
Definition at line 183 of file GCNSubtarget.h.
Referenced by hasAtomicCSubNoRtnInsts().
|
protected |
Definition at line 176 of file GCNSubtarget.h.
Referenced by hasAtomicDsPkAdd16Insts().
|
protected |
Definition at line 179 of file GCNSubtarget.h.
Referenced by hasAtomicFaddInsts(), and hasAtomicFaddNoRtnInsts().
|
protected |
Definition at line 178 of file GCNSubtarget.h.
Referenced by hasAtomicFaddInsts(), and hasAtomicFaddRtnInsts().
|
protected |
Definition at line 177 of file GCNSubtarget.h.
Referenced by hasAtomicFlatPkAdd16Insts().
|
protected |
Definition at line 174 of file GCNSubtarget.h.
Referenced by hasAtomicFMinFMaxF32FlatInsts().
|
protected |
Definition at line 172 of file GCNSubtarget.h.
Referenced by hasAtomicFMinFMaxF32GlobalInsts().
|
protected |
Definition at line 175 of file GCNSubtarget.h.
Referenced by hasAtomicFMinFMaxF64FlatInsts().
|
protected |
Definition at line 173 of file GCNSubtarget.h.
Referenced by hasAtomicFMinFMaxF64GlobalInsts().
|
protected |
Definition at line 184 of file GCNSubtarget.h.
Referenced by hasAtomicGlobalPkAddBF16Inst().
|
protected |
Definition at line 239 of file GCNSubtarget.h.
Referenced by hasBitOp3Insts().
|
protected |
Definition at line 244 of file GCNSubtarget.h.
Referenced by hasBVHDualAndBVH8Insts().
|
protected |
Definition at line 254 of file GCNSubtarget.h.
Referenced by hasCUStores().
|
protected |
Definition at line 170 of file GCNSubtarget.h.
Referenced by hasCvtFP8VOP1Bug().
|
protected |
Definition at line 191 of file GCNSubtarget.h.
Referenced by hasDefaultComponentBroadcast().
|
protected |
Definition at line 188 of file GCNSubtarget.h.
Referenced by hasDefaultComponentZero().
|
protected |
Definition at line 151 of file GCNSubtarget.h.
Referenced by hasDLInsts().
|
protected |
Definition at line 162 of file GCNSubtarget.h.
Referenced by hasDot10Insts().
|
protected |
Definition at line 163 of file GCNSubtarget.h.
Referenced by hasDot11Insts().
|
protected |
Definition at line 164 of file GCNSubtarget.h.
Referenced by hasDot12Insts().
|
protected |
Definition at line 165 of file GCNSubtarget.h.
Referenced by hasDot13Insts().
|
protected |
Definition at line 153 of file GCNSubtarget.h.
Referenced by hasDot1Insts().
|
protected |
Definition at line 154 of file GCNSubtarget.h.
Referenced by hasDot2Insts().
|
protected |
Definition at line 155 of file GCNSubtarget.h.
Referenced by hasDot3Insts().
|
protected |
Definition at line 156 of file GCNSubtarget.h.
Referenced by hasDot4Insts().
|
protected |
Definition at line 157 of file GCNSubtarget.h.
Referenced by hasDot5Insts().
|
protected |
Definition at line 158 of file GCNSubtarget.h.
Referenced by hasDot6Insts().
|
protected |
Definition at line 159 of file GCNSubtarget.h.
Referenced by hasDot7Insts().
|
protected |
Definition at line 160 of file GCNSubtarget.h.
Referenced by hasDot8Insts().
|
protected |
Definition at line 161 of file GCNSubtarget.h.
Referenced by hasDot9Insts().
|
protected |
Definition at line 139 of file GCNSubtarget.h.
Referenced by hasDPALU_DPP().
|
protected |
Definition at line 137 of file GCNSubtarget.h.
Referenced by hasDPP(), hasDPPBroadcasts(), and hasDPPWavefrontShifts().
|
protected |
Definition at line 138 of file GCNSubtarget.h.
Referenced by hasDPP8().
|
protected |
Definition at line 140 of file GCNSubtarget.h.
Referenced by hasDPPSrc1SGPR().
|
protected |
Definition at line 190 of file GCNSubtarget.h.
Referenced by hasEmulatedSystemScopeAtomics().
|
protected |
Definition at line 143 of file GCNSubtarget.h.
Referenced by hasExtendedImageInsts().
|
protected |
Definition at line 186 of file GCNSubtarget.h.
Referenced by hasFlatAtomicFaddF32Inst().
|
protected |
Definition at line 187 of file GCNSubtarget.h.
Referenced by hasFlatBufferGlobalAtomicFaddF64Inst().
|
protected |
Definition at line 260 of file GCNSubtarget.h.
Referenced by hasFlatSegmentOffsetBug().
|
protected |
Definition at line 152 of file GCNSubtarget.h.
Referenced by hasFmacF64Inst().
|
protected |
Definition at line 126 of file GCNSubtarget.h.
Referenced by hasFmaMixBF16Insts().
|
protected |
Definition at line 125 of file GCNSubtarget.h.
Referenced by hasFmaMixInsts().
|
protected |
Definition at line 168 of file GCNSubtarget.h.
Referenced by hasFP8ConversionInsts().
|
protected |
Definition at line 169 of file GCNSubtarget.h.
Referenced by hasFP8E5M3Insts().
|
protected |
Definition at line 167 of file GCNSubtarget.h.
Referenced by hasFP8Insts().
|
protected |
Definition at line 146 of file GCNSubtarget.h.
Referenced by hasG16().
|
protected |
Definition at line 225 of file GCNSubtarget.h.
Referenced by hasGDS().
|
protected |
Definition at line 210 of file GCNSubtarget.h.
Referenced by hasGetWaveIdInst().
|
protected |
Definition at line 286 of file GCNSubtarget.h.
Referenced by hasGloballyAddressableScratch().
|
protected |
Definition at line 226 of file GCNSubtarget.h.
Referenced by hasGWS().
|
protected |
Definition at line 272 of file GCNSubtarget.h.
Referenced by hasIEEEMinimumMaximumInsts().
|
protected |
Definition at line 262 of file GCNSubtarget.h.
Referenced by hasImageGather4D16Bug().
|
protected |
Definition at line 142 of file GCNSubtarget.h.
Referenced by hasImageInsts().
|
protected |
Definition at line 261 of file GCNSubtarget.h.
Referenced by hasImageStoreD16Bug().
|
protected |
Definition at line 250 of file GCNSubtarget.h.
Referenced by hasInstFwdPrefetchBug().
|
protected |
Definition at line 124 of file GCNSubtarget.h.
Referenced by hasIntClamp().
|
protected |
Definition at line 281 of file GCNSubtarget.h.
Referenced by hasLdsBarrierArriveAtomic().
|
protected |
Definition at line 256 of file GCNSubtarget.h.
Referenced by hasLdsBranchVmemWARHazard().
|
protected |
Definition at line 277 of file GCNSubtarget.h.
Referenced by hasLshlAddU64Inst().
|
protected |
Definition at line 266 of file GCNSubtarget.h.
Referenced by hasMADIntraFwdBug().
|
protected |
Definition at line 279 of file GCNSubtarget.h.
Referenced by hasMadU32Inst().
|
protected |
Definition at line 166 of file GCNSubtarget.h.
Referenced by hasMAIInsts().
|
protected |
Definition at line 180 of file GCNSubtarget.h.
Referenced by hasMemoryAtomicFaddF32DenormalSupport().
|
protected |
Definition at line 230 of file GCNSubtarget.h.
Referenced by hasMFMAInlineLiteralBug().
|
protected |
Definition at line 275 of file GCNSubtarget.h.
Referenced by hasMin3Max3PKF16().
|
protected |
Definition at line 274 of file GCNSubtarget.h.
Referenced by hasMinimum3Maximum3F16().
|
protected |
Definition at line 273 of file GCNSubtarget.h.
Referenced by hasMinimum3Maximum3F32().
|
protected |
Definition at line 276 of file GCNSubtarget.h.
Referenced by hasMinimum3Maximum3PKF16().
|
protected |
Definition at line 127 of file GCNSubtarget.h.
Referenced by hasMovrel().
|
protected |
Definition at line 263 of file GCNSubtarget.h.
Referenced by hasMSAALoadDstSelBug().
|
protected |
Definition at line 215 of file GCNSubtarget.h.
Referenced by hasNoDataDepHazard().
|
protected |
Definition at line 207 of file GCNSubtarget.h.
Referenced by hasNoSdstCMPX().
|
protected |
Definition at line 258 of file GCNSubtarget.h.
Referenced by hasNSAClauseBug().
|
protected |
Definition at line 147 of file GCNSubtarget.h.
Referenced by hasNSAEncoding().
|
protected |
Definition at line 257 of file GCNSubtarget.h.
Referenced by hasNSAtoVMEMBug().
|
protected |
Definition at line 259 of file GCNSubtarget.h.
Referenced by hasOffset3fBug().
|
protected |
Definition at line 141 of file GCNSubtarget.h.
Referenced by hasPackedFP32Ops().
|
protected |
Definition at line 233 of file GCNSubtarget.h.
Referenced by hasPackedTID().
|
protected |
Definition at line 148 of file GCNSubtarget.h.
Referenced by hasPartialNSAEncoding().
|
protected |
Definition at line 245 of file GCNSubtarget.h.
Referenced by hasPermlane16Swap().
|
protected |
Definition at line 246 of file GCNSubtarget.h.
Referenced by hasPermlane32Swap().
|
protected |
Definition at line 171 of file GCNSubtarget.h.
Referenced by hasPkFmacF16Inst().
|
protected |
Definition at line 280 of file GCNSubtarget.h.
Referenced by hasPointSampleAccel().
|
protected |
Definition at line 264 of file GCNSubtarget.h.
Referenced by hasPrivEnabledTrap2NopBug().
|
protected |
Definition at line 243 of file GCNSubtarget.h.
Referenced by hasPrngInst().
|
protected |
Definition at line 236 of file GCNSubtarget.h.
Referenced by hasPseudoScalarTrans().
|
protected |
Definition at line 144 of file GCNSubtarget.h.
Referenced by hasR128A16().
|
protected |
Definition at line 269 of file GCNSubtarget.h.
Referenced by hasRequiredExportPriority().
|
protected |
Definition at line 237 of file GCNSubtarget.h.
Referenced by hasRestrictedSOffset().
|
protected |
Definition at line 253 of file GCNSubtarget.h.
Referenced by hasSafeCUPrefetch().
|
protected |
Definition at line 252 of file GCNSubtarget.h.
Referenced by hasSafeSmemPrefetch().
|
protected |
Definition at line 235 of file GCNSubtarget.h.
Referenced by hasSALUFloatInsts().
|
protected |
Definition at line 131 of file GCNSubtarget.h.
Referenced by hasScalarAtomics().
|
protected |
Definition at line 129 of file GCNSubtarget.h.
Referenced by hasScalarDwordx3Loads().
|
protected |
Definition at line 130 of file GCNSubtarget.h.
Referenced by hasScalarStores().
|
protected |
Definition at line 135 of file GCNSubtarget.h.
Referenced by hasSDWAMac().
|
protected |
Definition at line 132 of file GCNSubtarget.h.
Referenced by hasSDWAOmod().
|
protected |
Definition at line 136 of file GCNSubtarget.h.
Referenced by hasSDWAOutModsVOPC().
|
protected |
Definition at line 133 of file GCNSubtarget.h.
Referenced by hasSDWAScalar().
|
protected |
Definition at line 134 of file GCNSubtarget.h.
Referenced by hasSDWASdst().
|
protected |
Definition at line 282 of file GCNSubtarget.h.
Referenced by hasSetPrioIncWgInst().
|
protected |
Definition at line 213 of file GCNSubtarget.h.
Referenced by hasShaderCyclesHiLoRegisters().
|
protected |
Definition at line 212 of file GCNSubtarget.h.
Referenced by hasShaderCyclesRegister().
|
protected |
Definition at line 123 of file GCNSubtarget.h.
Referenced by hasSMemRealTime().
|
protected |
Definition at line 211 of file GCNSubtarget.h.
Referenced by hasSMemTimeInst().
|
protected |
Definition at line 249 of file GCNSubtarget.h.
Referenced by hasSMEMtoVectorWriteHazard().
|
protected |
Definition at line 240 of file GCNSubtarget.h.
Referenced by hasTanhInsts().
|
protected |
Definition at line 241 of file GCNSubtarget.h.
Referenced by hasTensorCvtLutInsts().
|
protected |
Definition at line 242 of file GCNSubtarget.h.
Referenced by hasTransposeLoadF4F6Insts().
|
protected |
Definition at line 228 of file GCNSubtarget.h.
Referenced by hasUnpackedD16VMem().
|
protected |
Definition at line 268 of file GCNSubtarget.h.
Referenced by hasVALUTransUseHazard().
|
protected |
Definition at line 255 of file GCNSubtarget.h.
Referenced by hasVcmpxExecWARHazard().
|
protected |
Definition at line 247 of file GCNSubtarget.h.
Referenced by hasVcmpxPermlaneHazard().
|
protected |
Definition at line 128 of file GCNSubtarget.h.
Referenced by hasVGPRIndexMode().
|
protected |
Definition at line 251 of file GCNSubtarget.h.
Referenced by hasVmemPrefInsts().
|
protected |
Definition at line 200 of file GCNSubtarget.h.
Referenced by hasVMemToLDSLoad().
|
protected |
Definition at line 248 of file GCNSubtarget.h.
Referenced by hasVMEMtoScalarWriteHazard().
|
protected |
Definition at line 270 of file GCNSubtarget.h.
Referenced by hasVmemWriteVgprInOrder().
|
protected |
Definition at line 214 of file GCNSubtarget.h.
Referenced by hasVOP3Literal().
|
protected |
Definition at line 267 of file GCNSubtarget.h.
Referenced by hasVOPDInsts().
|
protected |
Definition at line 208 of file GCNSubtarget.h.
Referenced by hasVscnt().
|
protected |
Definition at line 209 of file GCNSubtarget.h.
Referenced by hasWaitXCnt().
|
protected |
Definition at line 192 of file GCNSubtarget.h.
Referenced by hasXF32Insts().
|
protected |
Definition at line 66 of file GCNSubtarget.h.
Referenced by getInstrItineraryData().
|
protected |
Definition at line 84 of file GCNSubtarget.h.
Referenced by hasKernargPreload().
|
protected |
Definition at line 67 of file GCNSubtarget.h.
Referenced by getLDSBankCount(), and initializeSubtargetDependencies().
|
protected |
Definition at line 229 of file GCNSubtarget.h.
Referenced by hasLDSMisalignedBug().
|
protected |
The maximum number of instructions that may be placed within an S_CLAUSE, which is one greater than the maximum argument to S_CLAUSE.
A value of 0 indicates a lack of S_CLAUSE support.
Definition at line 196 of file GCNSubtarget.h.
Referenced by hasHardClauses(), and maxHardClauseLength().
|
protected |
Definition at line 68 of file GCNSubtarget.h.
Referenced by getMaxPrivateElementSize(), and initializeSubtargetDependencies().
|
protected |
Definition at line 106 of file GCNSubtarget.h.
Referenced by hasMIMG_R128().
|
protected |
Definition at line 121 of file GCNSubtarget.h.
Referenced by hasNegativeScratchOffsetBug().
|
protected |
Definition at line 122 of file GCNSubtarget.h.
Referenced by hasNegativeUnalignedScratchOffsetBug().
|
protected |
Definition at line 81 of file GCNSubtarget.h.
Referenced by hasRelaxedBufferOOBMode().
|
protected |
Definition at line 201 of file GCNSubtarget.h.
Referenced by needsAlignedVGPRs().
|
protected |
Definition at line 284 of file GCNSubtarget.h.
Referenced by requiresCodeObjectV6().
|
protected |
Definition at line 221 of file GCNSubtarget.h.
Referenced by hasScalarFlatScratchInsts().
|
protected |
Definition at line 234 of file GCNSubtarget.h.
Referenced by getScalarizeGlobalBehavior(), and setScalarizeGlobalBehavior().
|
protected |
Definition at line 119 of file GCNSubtarget.h.
Referenced by hasSGPRInitBug().
|
protected |
Definition at line 197 of file GCNSubtarget.h.
|
protected |
Definition at line 83 of file GCNSubtarget.h.
|
protected |
Definition at line 64 of file GCNSubtarget.h.
Referenced by d16PreservesUnusedBits(), getTargetID(), initializeSubtargetDependencies(), and isXNACKEnabled().
|
protected |
Definition at line 63 of file GCNSubtarget.h.
|
protected |
Definition at line 92 of file GCNSubtarget.h.
Referenced by isTrapHandlerEnabled().
|
protected |
Definition at line 80 of file GCNSubtarget.h.
Referenced by hasUnalignedAccessMode(), hasUnalignedBufferAccessEnabled(), hasUnalignedDSAccessEnabled(), and hasUnalignedScratchAccessEnabled().
|
protected |
Definition at line 231 of file GCNSubtarget.h.
Referenced by hasUnalignedBufferAccess(), and hasUnalignedBufferAccessEnabled().
|
protected |
Definition at line 232 of file GCNSubtarget.h.
Referenced by hasUnalignedDSAccess(), and hasUnalignedDSAccessEnabled().
|
protected |
Definition at line 79 of file GCNSubtarget.h.
Referenced by hasUnalignedScratchAccess(), and hasUnalignedScratchAccessEnabled().
|
protected |
Definition at line 285 of file GCNSubtarget.h.
Referenced by useVGPRBlockOpsForCSR().
|
protected |
Definition at line 120 of file GCNSubtarget.h.
Referenced by hasUserSGPRInit16Bug().