LLVM 22.0.0git
CombinerHelper.cpp File Reference

Go to the source code of this file.

Macros

#define DEBUG_TYPE   "gi-combiner"

Functions

static unsigned littleEndianByteAt (const unsigned ByteWidth, const unsigned I)
static Register buildLogBase2 (Register V, MachineIRBuilder &MIB)
 Determines the LogBase2 value for a non-null input value using the transform: LogBase2(V) = (EltBits - 1) - ctlz(V).
static unsigned bigEndianByteAt (const unsigned ByteWidth, const unsigned I)
static std::optional< boolisBigEndian (const SmallDenseMap< int64_t, int64_t, 8 > &MemOffset2Idx, int64_t LowestIdx)
 Given a map from byte offsets in memory to indices in a load/store, determine if that map corresponds to a little or big endian byte pattern.
static unsigned getExtLoadOpcForExtend (unsigned ExtOpc)
static bool canFoldInAddressingMode (GLoadStore *MI, const TargetLowering &TLI, MachineRegisterInfo &MRI)
 Return true if 'MI' is a load or a store that may be fold it's address operand into the load / store addressing mode.
static unsigned getIndexedOpc (unsigned LdStOpc)
static APFloat constantFoldFpUnary (const MachineInstr &MI, const MachineRegisterInfo &MRI, const APFloat &Val)
static Register peekThroughBitcast (Register Reg, const MachineRegisterInfo &MRI)
static LLT getMidVTForTruncRightShiftCombine (LLT ShiftTy, LLT TruncTy)
static bool isConstValidTrue (const TargetLowering &TLI, unsigned ScalarSizeBits, int64_t Cst, bool IsVector, bool IsFP)
static std::optional< std::pair< GZExtLoad *, int64_t > > matchLoadAndBytePosition (Register Reg, unsigned MemSizeInBits, const MachineRegisterInfo &MRI)
 Helper function for findLoadOffsetsForLoadOrCombine.
static bool isContractableFMul (MachineInstr &MI, bool AllowFusionGlobally)
 Checks if MI is TargetOpcode::G_FMUL and contractable either due to global flags or MachineInstr flags.
static bool hasMoreUses (const MachineInstr &MI0, const MachineInstr &MI1, const MachineRegisterInfo &MRI)
static std::optional< unsignedgetMinUselessShift (KnownBits ValueKB, unsigned Opcode, std::optional< int64_t > &Result)
 Return the minimum useless shift amount that results in complete loss of the source value.
static void commuteMask (MutableArrayRef< int > Mask, const unsigned NumElems)

Variables

static cl::opt< boolForceLegalIndexing ("force-legal-indexing", cl::Hidden, cl::init(false), cl::desc("Force all indexed operations to be " "legal for the GlobalISel combiner"))
static cl::opt< unsignedPostIndexUseThreshold ("post-index-use-threshold", cl::Hidden, cl::init(32), cl::desc("Number of uses of a base pointer to check before it is no longer " "considered for post-indexing."))

Macro Definition Documentation

◆ DEBUG_TYPE

#define DEBUG_TYPE   "gi-combiner"

Definition at line 45 of file CombinerHelper.cpp.

Function Documentation

◆ bigEndianByteAt()

unsigned bigEndianByteAt ( const unsigned ByteWidth,
const unsigned I )
static
Returns
The big endian in-memory byte position of byte I in a ByteWidth bytes wide type.

E.g. Given a 4-byte type x, x[0] -> byte 3

Definition at line 106 of file CombinerHelper.cpp.

References assert(), and I.

Referenced by isBigEndian(), isBigEndian(), and llvm::CombinerHelper::matchLoadOrCombine().

◆ buildLogBase2()

Register buildLogBase2 ( Register V,
MachineIRBuilder & MIB )
static

Determines the LogBase2 value for a non-null input value using the transform: LogBase2(V) = (EltBits - 1) - ctlz(V).

Definition at line 94 of file CombinerHelper.cpp.

References llvm::sampleprof::Base, llvm::MachineIRBuilder::buildConstant(), llvm::MachineIRBuilder::buildCTLZ(), llvm::MachineIRBuilder::buildSub(), llvm::MachineIRBuilder::getMRI(), llvm::MachineInstrBuilder::getReg(), and MRI.

Referenced by llvm::CombinerHelper::applyUMulHToLShr().

◆ canFoldInAddressingMode()

bool canFoldInAddressingMode ( GLoadStore * MI,
const TargetLowering & TLI,
MachineRegisterInfo & MRI )
static

◆ commuteMask()

void commuteMask ( MutableArrayRef< int > Mask,
const unsigned NumElems )
static

Definition at line 8271 of file CombinerHelper.cpp.

References I.

Referenced by llvm::CombinerHelper::matchShuffleDisjointMask().

◆ constantFoldFpUnary()

◆ getExtLoadOpcForExtend()

unsigned getExtLoadOpcForExtend ( unsigned ExtOpc)
static

◆ getIndexedOpc()

unsigned getIndexedOpc ( unsigned LdStOpc)
static

Definition at line 1196 of file CombinerHelper.cpp.

References llvm_unreachable.

Referenced by llvm::CombinerHelper::applyCombineIndexedLoadStore().

◆ getMidVTForTruncRightShiftCombine()

LLT getMidVTForTruncRightShiftCombine ( LLT ShiftTy,
LLT TruncTy )
static

◆ getMinUselessShift()

std::optional< unsigned > getMinUselessShift ( KnownBits ValueKB,
unsigned Opcode,
std::optional< int64_t > & Result )
static

Return the minimum useless shift amount that results in complete loss of the source value.

Return std::nullopt when it cannot determine a value.

Definition at line 7002 of file CombinerHelper.cpp.

References assert(), llvm::KnownBits::countMinLeadingOnes(), llvm::KnownBits::countMinLeadingZeros(), llvm::KnownBits::countMinTrailingZeros(), llvm::KnownBits::getBitWidth(), llvm::KnownBits::isNegative(), and llvm::KnownBits::isNonNegative().

Referenced by llvm::CombinerHelper::matchShiftsTooBig().

◆ hasMoreUses()

◆ isBigEndian()

std::optional< bool > isBigEndian ( const SmallDenseMap< int64_t, int64_t, 8 > & MemOffset2Idx,
int64_t LowestIdx )
static

Given a map from byte offsets in memory to indices in a load/store, determine if that map corresponds to a little or big endian byte pattern.

Parameters
MemOffset2Idxmaps memory offsets to address offsets.
LowestIdxis the lowest index in MemOffset2Idx.
Returns
true if the map corresponds to a big endian byte pattern, false if it corresponds to a little endian byte pattern, and std::nullopt otherwise.

E.g. given a 32-bit type x, and x[AddrOffset], the in-memory byte patterns are as follows:

AddrOffset Little endian Big endian 0 0 3 1 1 2 2 2 1 3 3 0

Definition at line 129 of file CombinerHelper.cpp.

References assert(), bigEndianByteAt(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT, BucketT >::end(), llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT, BucketT >::find(), littleEndianByteAt(), and llvm::DenseMapBase< DerivedT, KeyT, ValueT, KeyInfoT, BucketT >::size().

Referenced by llvm::BuildVectorSDNode::BuildVectorSDNode(), collectInsertionElements(), createGPRPairNodei64(), llvm::SelectionDAG::getConstant(), llvm::CombinerHelper::matchLoadOrCombine(), PerformSTORECombine(), llvm::LegalizerHelper::reduceLoadStoreWidth(), ReplaceCMP_SWAP_64Results(), llvm::TargetLowering::scalarizeVectorLoad(), llvm::TargetLowering::scalarizeVectorStore(), llvm::wholeprogramdevirt::VirtualCallTarget::VirtualCallTarget(), and llvm::orc::OrcMips32_Base::writeResolverCode().

◆ isConstValidTrue()

bool isConstValidTrue ( const TargetLowering & TLI,
unsigned ScalarSizeBits,
int64_t Cst,
bool IsVector,
bool IsFP )
static

Definition at line 3506 of file CombinerHelper.cpp.

References llvm::isConstTrueVal().

Referenced by llvm::CombinerHelper::matchNotCmp().

◆ isContractableFMul()

◆ littleEndianByteAt()

unsigned littleEndianByteAt ( const unsigned ByteWidth,
const unsigned I )
static
Returns
The little endian in-memory byte position of byte I in a ByteWidth bytes wide type.

E.g. Given a 4-byte type x, x[0] -> byte 0

Definition at line 87 of file CombinerHelper.cpp.

References assert(), and I.

Referenced by isBigEndian(), isBigEndian(), and llvm::CombinerHelper::matchLoadOrCombine().

◆ matchLoadAndBytePosition()

std::optional< std::pair< GZExtLoad *, int64_t > > matchLoadAndBytePosition ( Register Reg,
unsigned MemSizeInBits,
const MachineRegisterInfo & MRI )
static

Helper function for findLoadOffsetsForLoadOrCombine.

Check if Reg is the result of loading a MemSizeInBits wide value, and then moving that value into a specific byte offset.

e.g. x[i] << 24

Returns
The load instruction and the byte offset it is moved into.

Definition at line 3980 of file CombinerHelper.cpp.

References assert(), llvm::getOpcodeDef(), llvm::MIPatternMatch::m_GShl(), llvm::MIPatternMatch::m_ICst(), llvm::MIPatternMatch::m_OneNonDBGUse(), llvm::MIPatternMatch::m_Reg(), llvm::MIPatternMatch::mi_match(), MRI, and Reg.

◆ peekThroughBitcast()

Variable Documentation

◆ ForceLegalIndexing

cl::opt< bool > ForceLegalIndexing("force-legal-indexing", cl::Hidden, cl::init(false), cl::desc("Force all indexed operations to be " "legal for the GlobalISel combiner")) ( "force-legal-indexing" ,
cl::Hidden ,
cl::init(false) ,
cl::desc("Force all indexed operations to be " "legal for the GlobalISel combiner")  )
static

◆ PostIndexUseThreshold

cl::opt< unsigned > PostIndexUseThreshold("post-index-use-threshold", cl::Hidden, cl::init(32), cl::desc("Number of uses of a base pointer to check before it is no longer " "considered for post-indexing.")) ( "post-index-use-threshold" ,
cl::Hidden ,
cl::init(32) ,
cl::desc("Number of uses of a base pointer to check before it is no longer " "considered for post-indexing.")  )
static