LLVM  14.0.0git
Namespaces | Macros | Functions | Variables
HexagonCopyToCombine.cpp File Reference
#include "HexagonInstrInfo.h"
#include "HexagonSubtarget.h"
#include "llvm/ADT/DenseMap.h"
#include "llvm/ADT/DenseSet.h"
#include "llvm/CodeGen/MachineBasicBlock.h"
#include "llvm/CodeGen/MachineFunction.h"
#include "llvm/CodeGen/MachineFunctionPass.h"
#include "llvm/CodeGen/MachineInstr.h"
#include "llvm/CodeGen/MachineInstrBuilder.h"
#include "llvm/CodeGen/Passes.h"
#include "llvm/CodeGen/TargetRegisterInfo.h"
#include "llvm/Pass.h"
#include "llvm/Support/CodeGen.h"
#include "llvm/Support/CommandLine.h"
#include "llvm/Support/Debug.h"
#include "llvm/Support/raw_ostream.h"
#include "llvm/Target/TargetMachine.h"
Include dependency graph for HexagonCopyToCombine.cpp:

Go to the source code of this file.

Namespaces

 llvm
 This is an optimization pass for GlobalISel generic memory operations.
 

Macros

#define DEBUG_TYPE   "hexagon-copy-combine"
 

Functions

FunctionPassllvm::createHexagonCopyToCombine ()
 
void llvm::initializeHexagonCopyToCombinePass (PassRegistry &)
 
 INITIALIZE_PASS (HexagonCopyToCombine, "hexagon-copy-combine", "Hexagon Copy-To-Combine Pass", false, false) static bool isCombinableInstType(MachineInstr &MI
 
template<unsigned N>
static bool isGreaterThanNBitTFRI (const MachineInstr &I)
 
static bool areCombinableOperations (const TargetRegisterInfo *TRI, MachineInstr &HighRegInst, MachineInstr &LowRegInst, bool AllowC64)
 areCombinableOperations - Returns true if the two instruction can be merge into a combine (ignoring register constraints). More...
 
static bool isEvenReg (unsigned Reg)
 
static void removeKillInfo (MachineInstr &MI, unsigned RegNotKilled)
 
static bool isUnsafeToMoveAcross (MachineInstr &MI, unsigned UseReg, unsigned DestReg, const TargetRegisterInfo *TRI)
 Returns true if it is unsafe to move a copy instruction from UseReg to DestReg over the instruction MI. More...
 
static Register UseReg (const MachineOperand &MO)
 

Variables

static cl::opt< bool > IsCombinesDisabled ("disable-merge-into-combines", cl::Hidden, cl::ZeroOrMore, cl::init(false), cl::desc("Disable merging into combines"))
 
static cl::opt< bool > IsConst64Disabled ("disable-const64", cl::Hidden, cl::ZeroOrMore, cl::init(false), cl::desc("Disable generation of const64"))
 
static cl::opt< unsigned > MaxNumOfInstsBetweenNewValueStoreAndTFR ("max-num-inst-between-tfr-and-nv-store", cl::Hidden, cl::init(4), cl::desc("Maximum distance between a tfr feeding a store we " "consider the store still to be newifiable"))
 
const HexagonInstrInfoTII
 
const HexagonInstrInfo bool ShouldCombineAggressively
 

Macro Definition Documentation

◆ DEBUG_TYPE

#define DEBUG_TYPE   "hexagon-copy-combine"

Definition at line 34 of file HexagonCopyToCombine.cpp.

Function Documentation

◆ areCombinableOperations()

static bool areCombinableOperations ( const TargetRegisterInfo TRI,
MachineInstr HighRegInst,
MachineInstr LowRegInst,
bool  AllowC64 
)
static

areCombinableOperations - Returns true if the two instruction can be merge into a combine (ignoring register constraints).

Definition at line 185 of file HexagonCopyToCombine.cpp.

References llvm::MachineInstr::getOpcode(), llvm::MachineInstr::getOperand(), IsConst64Disabled, llvm::MachineOperand::isImm(), and llvm_unreachable.

◆ INITIALIZE_PASS()

INITIALIZE_PASS ( HexagonCopyToCombine  ,
"hexagon-copy-combine ,
"Hexagon Copy-To-Combine Pass ,
false  ,
false   
) &

◆ isEvenReg()

static bool isEvenReg ( unsigned  Reg)
static

◆ isGreaterThanNBitTFRI()

template<unsigned N>
static bool isGreaterThanNBitTFRI ( const MachineInstr I)
static

Definition at line 174 of file HexagonCopyToCombine.cpp.

References I.

◆ isUnsafeToMoveAcross()

static bool isUnsafeToMoveAcross ( MachineInstr MI,
unsigned  UseReg,
unsigned  DestReg,
const TargetRegisterInfo TRI 
)
static

Returns true if it is unsafe to move a copy instruction from UseReg to DestReg over the instruction MI.

Definition at line 250 of file HexagonCopyToCombine.cpp.

References MI, TRI, and UseReg().

◆ removeKillInfo()

static void removeKillInfo ( MachineInstr MI,
unsigned  RegNotKilled 
)
static

Definition at line 239 of file HexagonCopyToCombine.cpp.

References E, I, and MI.

◆ UseReg()

static Register UseReg ( const MachineOperand MO)
static

Variable Documentation

◆ IsCombinesDisabled

cl::opt<bool> IsCombinesDisabled("disable-merge-into-combines", cl::Hidden, cl::ZeroOrMore, cl::init(false), cl::desc("Disable merging into combines"))
static

◆ IsConst64Disabled

cl::opt<bool> IsConst64Disabled("disable-const64", cl::Hidden, cl::ZeroOrMore, cl::init(false), cl::desc("Disable generation of const64"))
static

Referenced by areCombinableOperations().

◆ MaxNumOfInstsBetweenNewValueStoreAndTFR

cl::opt<unsigned> MaxNumOfInstsBetweenNewValueStoreAndTFR("max-num-inst-between-tfr-and-nv-store", cl::Hidden, cl::init(4), cl::desc("Maximum distance between a tfr feeding a store we " "consider the store still to be newifiable"))
static

◆ ShouldCombineAggressively

const HexagonInstrInfo bool ShouldCombineAggressively

Definition at line 130 of file HexagonCopyToCombine.cpp.

◆ TII

Definition at line 129 of file HexagonCopyToCombine.cpp.

Referenced by llvm::SITargetLowering::AddIMGInit(), llvm::MachineBasicBlock::addLiveIn(), AdjustBaseAndOffset(), llvm::ARMFrameLowering::adjustForSegmentedStacks(), llvm::SIFrameLowering::allocateScavengingFrameIndexesNearIncomingSP(), appendEndToFunction(), areCandidatesToMergeOrPair(), llvm::ARMBasicBlockUtils::ARMBasicBlockUtils(), attemptDebugCopyProp(), llvm::DwarfDebug::beginInstruction(), buildAddr64RSrc(), buildGitPtr(), buildMUBUFOffsetLoadStore(), buildOffsetSrc(), buildScratchExecCopy(), llvm::SIRegisterInfo::buildSpillLoadStore(), llvm::SITargetLowering::bundleInstWithWaitcnt(), canClobberPhysRegDefs(), canClobberReachingPhysRegUse(), llvm::MachineBasicBlock::canSplitCriticalEdge(), CheckForPhysRegDependency(), CMSEPopCalleeSaves(), CMSEPushCalleeSaves(), CombineCVTAToLocal(), combineRestoreADD(), combineRestoreOR(), combineRestoreSETHIi(), llvm::MachineFrameInfo::computeMaxCallFrameSize(), llvm::MachineInstrBuilder::constrainAllUses(), llvm::constrainOperandRegClass(), llvm::constrainSelectedInstRegOperands(), convertCalleeSaveRestoreToSPPrePostIncDec(), convertImplicitDefToConstZero(), copyDebugInfoToPredecessor(), copyDebugInfoToSuccessor(), createBBSelectReg(), llvm::createBURRListDAGScheduler(), llvm::createCopyConstrainDAGMutation(), llvm::createHybridListDAGScheduler(), llvm::createILPListDAGScheduler(), llvm::createLoadClusterDAGMutation(), createPHIsForCMOVsInSinkBB(), createPHIsForSelects(), createPostIncLoadStore(), createScratchRegisterForInstruction(), llvm::createSourceListDAGScheduler(), llvm::createStoreClusterDAGMutation(), llvm::TargetInstrInfo::describeLoadedValue(), describeORRLoadedValue(), llvm::Mips16FrameLowering::determineCalleeSaves(), llvm::ARMFrameLowering::determineCalleeSaves(), dropInstructionKeepingImpDefs(), llvm::MSP430FrameLowering::eliminateCallFramePseudoInstr(), llvm::AArch64FrameLowering::eliminateCallFramePseudoInstr(), llvm::WebAssemblyFrameLowering::eliminateCallFramePseudoInstr(), llvm::AVRFrameLowering::eliminateCallFramePseudoInstr(), llvm::Thumb1FrameLowering::eliminateCallFramePseudoInstr(), llvm::XCoreFrameLowering::eliminateCallFramePseudoInstr(), llvm::SIFrameLowering::eliminateCallFramePseudoInstr(), llvm::ARCFrameLowering::eliminateCallFramePseudoInstr(), llvm::PPCFrameLowering::eliminateCallFramePseudoInstr(), llvm::BPFRegisterInfo::eliminateFrameIndex(), llvm::MSP430RegisterInfo::eliminateFrameIndex(), llvm::LanaiRegisterInfo::eliminateFrameIndex(), llvm::SparcRegisterInfo::eliminateFrameIndex(), llvm::WebAssemblyRegisterInfo::eliminateFrameIndex(), llvm::XCoreRegisterInfo::eliminateFrameIndex(), llvm::VERegisterInfo::eliminateFrameIndex(), llvm::AVRRegisterInfo::eliminateFrameIndex(), llvm::ARCRegisterInfo::eliminateFrameIndex(), llvm::RISCVRegisterInfo::eliminateFrameIndex(), llvm::ThumbRegisterInfo::eliminateFrameIndex(), llvm::AArch64RegisterInfo::eliminateFrameIndex(), llvm::SIRegisterInfo::eliminateFrameIndex(), llvm::PPCRegisterInfo::eliminateFrameIndex(), llvm::SystemZRegisterInfo::eliminateFrameIndex(), llvm::ARMBaseRegisterInfo::eliminateFrameIndex(), emitAlignedDPRCS2Restores(), emitAlignedDPRCS2Spills(), emitAligningInstructions(), llvm::emitARMRegPlusImmediate(), llvm::PPCTargetLowering::EmitAtomicBinary(), emitBuildPairF64Pseudo(), llvm::AArch64FrameLowering::emitCalleeSavedFrameMoves(), emitCallSPUpdate(), EmitCfiOffset(), emitComments(), EmitDefCfaOffset(), EmitDefCfaRegister(), llvm::VETargetLowering::emitEHSjLjLongJmp(), llvm::PPCTargetLowering::emitEHSjLjLongJmp(), llvm::VETargetLowering::emitEHSjLjSetJmp(), llvm::PPCTargetLowering::emitEHSjLjSetJmp(), llvm::SIFrameLowering::emitEntryFunctionPrologue(), llvm::AVRFrameLowering::emitEpilogue(), llvm::Thumb1FrameLowering::emitEpilogue(), llvm::Mips16FrameLowering::emitEpilogue(), llvm::MipsSEFrameLowering::emitEpilogue(), llvm::SparcFrameLowering::emitEpilogue(), llvm::VEFrameLowering::emitEpilogue(), llvm::MSP430FrameLowering::emitEpilogue(), llvm::XCoreFrameLowering::emitEpilogue(), llvm::ARMFrameLowering::emitEpilogue(), llvm::SIFrameLowering::emitEpilogue(), llvm::ARCFrameLowering::emitEpilogue(), llvm::AArch64FrameLowering::emitEpilogue(), llvm::WebAssemblyFrameLowering::emitEpilogue(), llvm::PPCFrameLowering::emitEpilogue(), llvm::VEFrameLowering::emitEpilogueInsns(), llvm::AArch64TargetLowering::EmitF128CSEL(), llvm::emitFrameOffset(), emitFrameOffsetAdj(), emitGPDisp(), llvm::SITargetLowering::emitGWSMemViolTestLoop(), emitIncrement(), emitIndirectDst(), emitIndirectSrc(), llvm::R600TargetLowering::EmitInstrWithCustomInserter(), llvm::BPFTargetLowering::EmitInstrWithCustomInserter(), llvm::AVRTargetLowering::EmitInstrWithCustomInserter(), llvm::XCoreTargetLowering::EmitInstrWithCustomInserter(), llvm::MSP430TargetLowering::EmitInstrWithCustomInserter(), llvm::SITargetLowering::EmitInstrWithCustomInserter(), llvm::ARMTargetLowering::EmitInstrWithCustomInserter(), llvm::PPCTargetLowering::EmitInstrWithCustomInserter(), llvm::X86TargetLowering::EmitInstrWithCustomInserter(), llvm::MachineRegisterInfo::EmitLiveInCopies(), emitLoad(), llvm::ARMBaseRegisterInfo::emitLoadConstPool(), emitLoadM0FromVGPRLoop(), emitLoadSRsrcFromVGPRLoop(), TransferTracker::emitMOLoc(), llvm::PPCTargetLowering::EmitPartwordAtomicBinary(), emitPostLd(), emitPostSt(), llvm::PPCTargetLowering::emitProbedAlloca(), llvm::AVRFrameLowering::emitPrologue(), llvm::Thumb1FrameLowering::emitPrologue(), llvm::Mips16FrameLowering::emitPrologue(), llvm::MipsSEFrameLowering::emitPrologue(), llvm::VEFrameLowering::emitPrologue(), llvm::SparcFrameLowering::emitPrologue(), llvm::XCoreFrameLowering::emitPrologue(), llvm::MSP430FrameLowering::emitPrologue(), llvm::SIFrameLowering::emitPrologue(), llvm::RISCVFrameLowering::emitPrologue(), llvm::ARMFrameLowering::emitPrologue(), llvm::ARCFrameLowering::emitPrologue(), llvm::AArch64FrameLowering::emitPrologue(), llvm::WebAssemblyFrameLowering::emitPrologue(), llvm::PPCFrameLowering::emitPrologue(), emitPrologueEpilogueSPUpdate(), llvm::VEFrameLowering::emitPrologueInsns(), emitReadCycleWidePseudo(), emitRegPlusImmediate(), emitRegUpdate(), emitSCSEpilogue(), emitSCSPrologue(), emitSelectPseudo(), llvm::MSP430TargetLowering::EmitShiftInstr(), llvm::VETargetLowering::emitSjLjDispatchBlock(), emitSplitF64Pseudo(), emitSPUpdate(), emitStore(), llvm::emitT2RegPlusImmediate(), emitThumb1LoadConstPool(), emitThumb2LoadConstPool(), llvm::emitThumbRegPlusImmediate(), emitThumbRegPlusImmInReg(), emitXBegin(), EstimateFunctionSizeInBytes(), estimateRSStackSizeLimit(), llvm::InstructionSelector::executeMatchTable(), llvm::VEInstrInfo::expandExtendStackPseudo(), llvm::VEInstrInfo::expandGetStackTopPseudo(), expandLoadStackGuard(), expandMOV32r1(), ExpandMOVImmSExti8(), llvm::HexagonInstrInfo::expandPostRAPseudo(), llvm::AArch64InstrInfo::expandPostRAPseudo(), llvm::SparcTargetLowering::expandSelectCC(), expandSGPRCopy(), expandXorFP(), extractRsrcPtr(), llvm::FastISel::fastEmitBranch(), llvm::finalizeBundle(), llvm::MachineFunction::finalizeDebugInstrRefs(), llvm::SITargetLowering::finalizeLowering(), FindCallSeqStart(), findHoistingInsertPosAndDeps(), findOnlyInterestingUse(), llvm::fixStackStores(), FixTail(), fixTerminators(), foldImmediates(), foldPatchpoint(), llvm::InstCombinerImpl::foldSelectOpOp(), foldVGPRCopyIntoRegSequence(), for(), forceReg(), frameIndexMayFold(), FuseInst(), FuseTwoAddrInst(), llvm::AArch64InstrInfo::genAlternativeCodeSequence(), generateEndPgm(), generateStackAdjustment(), genFusedMultiply(), genFusedMultiplyAcc(), genFusedMultiplyAccNeg(), genFusedMultiplyIdx(), genFusedMultiplyIdxNeg(), genIndexedMultiply(), genMaddR(), genNeg(), genTPEntry(), genTPLoopBody(), getBBAddrMapMetadata(), getBBFallenThrough(), llvm::SIMachineFunctionInfo::getBufferPSV(), getCopyRewriter(), llvm::getEHScopeMembership(), llvm::MachineBasicBlock::getFallThrough(), getFirstNonPrologue(), getFlatScratchSpillOpcode(), llvm::MachineInstr::getFoldedRestoreSize(), llvm::MachineInstr::getFoldedSpillSize(), llvm::getFunctionLiveInPhysReg(), llvm::SIMachineFunctionInfo::getGWSPSV(), llvm::ARMHazardRecognizerFPMLx::getHazardType(), getHWReg(), llvm::SIMachineFunctionInfo::getImagePSV(), getIndirectSGPRIdx(), llvm::TargetSchedModel::getInstrInfo(), llvm::RegisterBankInfo::getInstrMappingImpl(), llvm::MSP430InstrInfo::getInstSizeInBytes(), llvm::AVRInstrInfo::getInstSizeInBytes(), getInstSizeInBytes(), llvm::SystemZTTIImpl::getIntImmCostInst(), getLastNonPseudo(), getNewSource(), getNumAllocatableRegsForConstraints(), llvm::SDNode::getOperationName(), getOrCreateFrameHelper(), getPhysicalRegisterVT(), llvm::SITargetLowering::getPrefLoopAlignment(), llvm::PPCTargetLowering::getPrefLoopAlignment(), llvm::RegisterBankInfo::getRegBankFromConstraints(), llvm::MachineInstr::getRegClassConstraint(), llvm::MachineInstr::getRegClassConstraintEffect(), llvm::MachineInstr::getRegClassConstraintEffectForVReg(), getRegClassForUnfoldedLoad(), getRegSeqInit(), llvm::R600RegisterInfo::getReservedRegs(), llvm::MachineInstr::getRestoreSize(), getSchedRegions(), llvm::ARMTargetLowering::getSchedulingPreference(), llvm::MachineInstr::getSpillSize(), getTargetFlagName(), getTargetIndexName(), getTargetMMOFlagName(), llvm::RISCVInstrInfo::getVLENFactoredAmount(), hasAnyNonFlatUseOfReg(), hasRVVSpillWithFIs(), hasSameValue(), llvm::HexagonHazardRecognizer::HexagonHazardRecognizer(), hoistAndMergeSGPRInits(), IfNeededExtSP(), IfNeededLDAWSP(), indirectCopyToAGPR(), llvm::MipsFunctionInfo::initGlobalBaseReg(), llvm::R600SchedStrategy::initialize(), llvm::ConvergingVLIWScheduler::initialize(), INITIALIZE_PASS(), llvm::PPCFrameLowering::inlineStackProbe(), insertCopy(), insertCSRRestores(), insertCSRSaves(), insertDeleteInstructions(), insertDivByZeroTrap(), InsertFPConstInst(), InsertFPImmInst(), InsertLDR_STR(), InsertNewDef(), insertNoopsInBundle(), insertNopBeforeInstruction(), insertPHI(), InsertReturnAddressAuth(), InsertSEH(), InsertSPConstInst(), InsertSPImmInst(), InsertUncondBranch(), insertUndefLaneMask(), interpretValues(), IsChainDependent(), llvm::SIRegisterInfo::isFrameOffsetLegal(), isInlineConstantIfFolded(), isKilled(), isKImmOperand(), isKImmOrKUImmOperand(), isKUImmOperand(), isLdOffsetInRangeOfSt(), llvm::isLegalAddressImm(), isLegalOrConvertableAddressImm(), isLibCallInTailPosition(), isLoadStoreThatCanHandleDisplacement(), llvm::MachineLoop::isLoopInvariant(), isRematerializable(), isReverseInlineImm(), isSafeToFoldImmIntoCopy(), isSchedBoundary(), isSendMsgTraceDataOrGDS(), isSignExtended(), isUseSafeToFold(), llvm::SystemZVectorConstantInfo::isVectorConstantLegal(), llvm::MipsLegalizerInfo::legalizeIntrinsic(), llvm::LiveRangeEdit::LiveRangeEdit(), loadM0FromVGPR(), AMDGPUMCInstLower::lower(), llvm::LegalizerHelper::lower(), llvm::PPCRegisterInfo::lowerACCRestore(), llvm::PPCRegisterInfo::lowerACCSpilling(), llvm::LegalizerHelper::lowerBitCount(), llvm::X86CallLowering::lowerCall(), LowerCallResults(), llvm::PPCRegisterInfo::lowerCRBitRestore(), llvm::PPCRegisterInfo::lowerCRBitSpilling(), llvm::PPCRegisterInfo::lowerCRRestore(), llvm::PPCRegisterInfo::lowerCRSpilling(), llvm::PPCRegisterInfo::lowerDynamicAlloc(), llvm::PPCRegisterInfo::lowerDynamicAreaOffset(), LowerFPToInt(), llvm::PPCRegisterInfo::lowerPrepareProbedAlloca(), llvm::PPCRegisterInfo::lowerQuadwordRestore(), llvm::PPCRegisterInfo::lowerQuadwordSpilling(), MakeM0Inst(), MatchingStackOffset(), matchSwap(), llvm::SIRegisterInfo::materializeFrameBaseRegister(), llvm::AArch64RegisterInfo::materializeFrameBaseRegister(), llvm::PPCRegisterInfo::materializeFrameBaseRegister(), llvm::ARMBaseRegisterInfo::materializeFrameBaseRegister(), llvm::MachineInstr::mayAlias(), llvm::ModuloScheduleExpander::ModuloScheduleExpander(), moveAndTeeForMultiUse(), llvm::SIRegisterInfo::needsFrameBaseReg(), llvm::AMDGPUMIRFormatter::parseCustomPseudoSourceValue(), llvm::PeelSingleBlockLoop(), performCopyPropagation(), llvm::PPCRegisterInfo::prepareDynamicAlloca(), llvm::VETargetLowering::prepareMBB(), llvm::VETargetLowering::prepareSymbol(), llvm::MIPrinter::print(), llvm::MachineOperand::print(), llvm::MachineMemOperand::print(), llvm::MachineBasicBlock::print(), llvm::MachineInstr::print(), printMemOperand(), llvm::MachineOperand::printTargetFlags(), llvm::RISCVFrameLowering::processFunctionBeforeFrameFinalized(), llvm::SIFrameLowering::processFunctionBeforeFrameFinalized(), llvm::AArch64FrameLowering::processFunctionBeforeFrameFinalized(), llvm::PseudoSourceValue::PseudoSourceValue(), llvm::TargetInstrInfo::reassociateOps(), llvm::MachineRegisterInfo::recomputeRegClass(), rematerializeCheapDef(), removeTerminatorBit(), replaceFI(), replaceFrameIndex(), reportIllegalCopy(), llvm::ThumbRegisterInfo::resolveFrameIndex(), llvm::SIRegisterInfo::resolveFrameIndex(), llvm::AArch64RegisterInfo::resolveFrameIndex(), llvm::PPCRegisterInfo::resolveFrameIndex(), llvm::ARMBaseRegisterInfo::resolveFrameIndex(), llvm::AVRFrameLowering::restoreCalleeSavedRegisters(), llvm::Thumb1FrameLowering::restoreCalleeSavedRegisters(), llvm::XCoreFrameLowering::restoreCalleeSavedRegisters(), llvm::MSP430FrameLowering::restoreCalleeSavedRegisters(), llvm::RISCVFrameLowering::restoreCalleeSavedRegisters(), llvm::AArch64FrameLowering::restoreCalleeSavedRegisters(), llvm::SystemZELFFrameLowering::restoreCalleeSavedRegisters(), llvm::PPCFrameLowering::restoreCalleeSavedRegisters(), restoreCRs(), RestoreSpillList(), llvm::restoreStatusRegister(), llvm::RevertDoLoopStart(), llvm::RevertLoopDec(), llvm::RevertLoopEnd(), RevertWhileLoopSetup(), llvm::RevertWhileLoopStartLR(), llvm::rewriteAArch64FrameIndex(), llvm::rewriteARMFrameIndex(), llvm::ThumbRegisterInfo::rewriteFrameIndex(), llvm::rewriteT2FrameIndex(), llvm::InsertNOPLoad::runOnMachineFunction(), llvm::FixAllFDIVSQRT::runOnMachineFunction(), llvm::VirtRegMap::runOnMachineFunction(), llvm::MachinePipeliner::runOnMachineFunction(), llvm::AVRDynAllocaSR::runOnMachineFunction(), llvm::MachineFunction::salvageCopySSA(), salvageDebugInfoFromEmptyBlock(), llvm::Mips16RegisterInfo::saveScavengerRegister(), llvm::FastISel::selectBitCast(), llvm::FastISel::selectCall(), selectCopy(), llvm::FastISel::selectFreeze(), llvm::FastISel::selectIntrinsicCall(), selectMergeValues(), llvm::FastISel::selectPatchpoint(), llvm::FastISel::selectStackmap(), selectUnmergeValues(), llvm::FastISel::selectXRayCustomEvent(), llvm::FastISel::selectXRayTypedEvent(), llvm::FunctionLoweringInfo::set(), setCallTargetReg(), setM0ToIndexFromSGPR(), llvm::VETargetLowering::setupEntryBlockForSjLj(), llvm::TargetRegisterInfo::shouldRegionSplitForVirtReg(), shouldRematerialize(), shrinkScalarCompare(), shrinkScalarLogicOp(), signOutlinedFunction(), SinkingPreventsImplicitNullCheck(), llvm::MachineBasicBlock::SkipPHIsAndLabels(), llvm::MachineBasicBlock::SkipPHIsLabelsAndDebug(), llvm::AVRFrameLowering::spillCalleeSavedRegisters(), llvm::Thumb1FrameLowering::spillCalleeSavedRegisters(), llvm::MipsSEFrameLowering::spillCalleeSavedRegisters(), llvm::XCoreFrameLowering::spillCalleeSavedRegisters(), llvm::MSP430FrameLowering::spillCalleeSavedRegisters(), llvm::RISCVFrameLowering::spillCalleeSavedRegisters(), llvm::AArch64FrameLowering::spillCalleeSavedRegisters(), llvm::SystemZELFFrameLowering::spillCalleeSavedRegisters(), llvm::SystemZXPLINKFrameLowering::spillCalleeSavedRegisters(), llvm::PPCFrameLowering::spillCalleeSavedRegisters(), spillVGPRtoAGPR(), llvm::MachineBasicBlock::SplitCriticalEdge(), splitEdge(), llvm::SITargetLowering::splitKillBlock(), splitMBB(), llvm::SystemZHazardRecognizer::SystemZHazardRecognizer(), tryAddToFoldList(), tryChangeVGPRtoSGPRinCopy(), tryConstantFoldOp(), tryOptimizeLEAtoMOV(), tryToFoldACImm(), tryToGetTargetInfo(), unstackifyVRegsUsedInSplitBB(), updateOperand(), UpdateOperandRegClass(), updateOperandRegConstraints(), llvm::MachineBasicBlock::updateTerminator(), usedAsAddr(), llvm::VirtRegMap::VirtRegMap(), llvm::SITargetLowering::wrapAddr64Rsrc(), and llvm::WebAssemblyFrameLowering::writeSPToGlobal().