LLVM  8.0.1
Public Member Functions | Static Public Member Functions | Public Attributes | List of all members
llvm::MachinePointerInfo Struct Reference

This class contains a discriminated union of information about pointers in memory operands, relating them back to LLVM IR or to virtual locations (such as frame indices) that are exposed during codegen. More...

#include "llvm/CodeGen/MachineMemOperand.h"

Collaboration diagram for llvm::MachinePointerInfo:
Collaboration graph
[legend]

Public Member Functions

 MachinePointerInfo (const Value *v, int64_t offset=0, uint8_t ID=0)
 
 MachinePointerInfo (const PseudoSourceValue *v, int64_t offset=0, uint8_t ID=0)
 
 MachinePointerInfo (unsigned AddressSpace=0)
 
 MachinePointerInfo (PointerUnion< const Value *, const PseudoSourceValue *> v, int64_t offset=0, uint8_t ID=0)
 
MachinePointerInfo getWithOffset (int64_t O) const
 
bool isDereferenceable (unsigned Size, LLVMContext &C, const DataLayout &DL) const
 Return true if memory region [V, V+Offset+Size) is known to be dereferenceable. More...
 
unsigned getAddrSpace () const
 Return the LLVM IR address space number that this pointer points into. More...
 

Static Public Member Functions

static MachinePointerInfo getConstantPool (MachineFunction &MF)
 Return a MachinePointerInfo record that refers to the constant pool. More...
 
static MachinePointerInfo getFixedStack (MachineFunction &MF, int FI, int64_t Offset=0)
 Return a MachinePointerInfo record that refers to the specified FrameIndex. More...
 
static MachinePointerInfo getJumpTable (MachineFunction &MF)
 Return a MachinePointerInfo record that refers to a jump table entry. More...
 
static MachinePointerInfo getGOT (MachineFunction &MF)
 Return a MachinePointerInfo record that refers to a GOT entry. More...
 
static MachinePointerInfo getStack (MachineFunction &MF, int64_t Offset, uint8_t ID=0)
 Stack pointer relative access. More...
 
static MachinePointerInfo getUnknownStack (MachineFunction &MF)
 Stack memory without other information. More...
 

Public Attributes

PointerUnion< const Value *, const PseudoSourceValue * > V
 This is the IR pointer value for the access, or it is null if unknown. More...
 
int64_t Offset
 Offset - This is an offset from the base Value*. More...
 
uint8_t StackID
 
unsigned AddrSpace = 0
 

Detailed Description

This class contains a discriminated union of information about pointers in memory operands, relating them back to LLVM IR or to virtual locations (such as frame indices) that are exposed during codegen.

Definition at line 39 of file MachineMemOperand.h.

Constructor & Destructor Documentation

◆ MachinePointerInfo() [1/4]

llvm::MachinePointerInfo::MachinePointerInfo ( const Value v,
int64_t  offset = 0,
uint8_t  ID = 0 
)
inlineexplicit

Definition at line 52 of file MachineMemOperand.h.

References llvm::Type::getPointerAddressSpace(), and llvm::Value::getType().

Referenced by getWithOffset().

◆ MachinePointerInfo() [2/4]

llvm::MachinePointerInfo::MachinePointerInfo ( const PseudoSourceValue v,
int64_t  offset = 0,
uint8_t  ID = 0 
)
inlineexplicit

Definition at line 58 of file MachineMemOperand.h.

References llvm::PseudoSourceValue::getAddressSpace().

◆ MachinePointerInfo() [3/4]

llvm::MachinePointerInfo::MachinePointerInfo ( unsigned  AddressSpace = 0)
inlineexplicit

Definition at line 64 of file MachineMemOperand.h.

◆ MachinePointerInfo() [4/4]

llvm::MachinePointerInfo::MachinePointerInfo ( PointerUnion< const Value *, const PseudoSourceValue *>  v,
int64_t  offset = 0,
uint8_t  ID = 0 
)
inlineexplicit

Member Function Documentation

◆ getAddrSpace()

unsigned MachinePointerInfo::getAddrSpace ( ) const

◆ getConstantPool()

MachinePointerInfo MachinePointerInfo::getConstantPool ( MachineFunction MF)
static

◆ getFixedStack()

MachinePointerInfo MachinePointerInfo::getFixedStack ( MachineFunction MF,
int  FI,
int64_t  Offset = 0 
)
static

Return a MachinePointerInfo record that refers to the specified FrameIndex.

getFixedStack - Return a MachinePointerInfo record that refers to the the specified FrameIndex.

Definition at line 964 of file MachineOperand.cpp.

References llvm::PseudoSourceValueManager::getFixedStack(), and llvm::MachineFunction::getPSVManager().

Referenced by llvm::AArch64CallLowering::AArch64CallLowering(), llvm::addFrameReference(), llvm::analyzeArguments(), AnalyzeReturnValues(), llvm::X86TargetLowering::BuildFILD(), CallingConvSupported(), CC_Lanai32_VarArg(), CC_MipsO32_FP64(), llvm::AArch64TargetLowering::CCAssignFnForReturn(), emitBuildPairF64Pseudo(), emitClzero(), llvm::TargetLoweringBase::emitPatchPoint(), emitSplitF64Pseudo(), EmitTailCallStoreFPAndRetAddr(), EmitTailCallStoreRetAddr(), llvm::TargetLowering::expandUnalignedLoad(), llvm::TargetLowering::expandUnalignedStore(), llvm::TargetInstrInfo::foldMemoryOperand(), getAddressForMemoryInput(), getComparePred(), getFrameIndexMMO(), llvm::MipsInstrInfo::GetMemOperand(), getMOVL(), getOffsetFromIndices(), getUnderlyingArgReg(), getVectorCompareInfo(), getWithOffset(), llvm::MipsCallLowering::MipsHandler::handle(), haveEfficientBuildVectorPattern(), InferPointerInfo(), isMulPowOf2(), isSortedByValueNo(), llvm::SITargetLowering::isTypeDesirableForOp(), llvm::MSP430InstrInfo::loadRegFromStackSlot(), llvm::Thumb1InstrInfo::loadRegFromStackSlot(), llvm::Thumb2InstrInfo::loadRegFromStackSlot(), llvm::XCoreInstrInfo::loadRegFromStackSlot(), llvm::ARCInstrInfo::loadRegFromStackSlot(), llvm::AVRInstrInfo::loadRegFromStackSlot(), llvm::SparcInstrInfo::loadRegFromStackSlot(), llvm::AArch64InstrInfo::loadRegFromStackSlot(), llvm::HexagonInstrInfo::loadRegFromStackSlot(), llvm::ARMBaseInstrInfo::loadRegFromStackSlot(), llvm::SIInstrInfo::loadRegFromStackSlot(), llvm::PPCInstrInfo::loadRegFromStackSlot(), LowerADJUST_TRAMPOLINE(), llvm::SITargetLowering::LowerCall(), llvm::SystemZTargetLowering::LowerCall(), lowerCallResult(), LowerCallResult(), llvm::SelectionDAGBuilder::LowerCallSiteWithDeoptBundle(), llvm::HexagonTargetLowering::LowerFormalArguments(), llvm::SystemZTargetLowering::LowerFormalArguments(), llvm::SparcTargetLowering::LowerFormalArguments_64(), LowerI64IntToFP_AVX512DQ(), llvm::X86CallLowering::lowerReturn(), llvm::ARMCallLowering::lowerReturn(), lowerUINT_TO_FP_vec(), LowerVASTART(), mayTailCallThisCC(), PrepareCall(), llvm::ARMTargetLowering::ReplaceNodeResults(), llvm::AArch64FrameLowering::restoreCalleeSavedRegisters(), llvm::SIRegisterInfo::restoreSGPR(), shouldGuaranteeTCO(), llvm::AArch64FrameLowering::spillCalleeSavedRegisters(), spillIncomingStatepointValue(), llvm::SIRegisterInfo::spillSGPR(), llvm::MSP430InstrInfo::storeRegToStackSlot(), llvm::Thumb1InstrInfo::storeRegToStackSlot(), llvm::Thumb2InstrInfo::storeRegToStackSlot(), llvm::XCoreInstrInfo::storeRegToStackSlot(), llvm::ARCInstrInfo::storeRegToStackSlot(), llvm::AVRInstrInfo::storeRegToStackSlot(), llvm::SparcInstrInfo::storeRegToStackSlot(), llvm::AArch64InstrInfo::storeRegToStackSlot(), llvm::HexagonInstrInfo::storeRegToStackSlot(), llvm::ARMBaseInstrInfo::storeRegToStackSlot(), llvm::SIInstrInfo::storeRegToStackSlot(), llvm::PPCInstrInfo::storeRegToStackSlot(), StoreTailCallArgumentsToStackSlot(), unpackF64OnRV32DSoftABI(), UnpackFromArgumentSlot(), unpackFromMemLoc(), llvm::SelectionDAGBuilder::visitSPDescriptorParent(), and widenVec().

◆ getGOT()

MachinePointerInfo MachinePointerInfo::getGOT ( MachineFunction MF)
static

◆ getJumpTable()

MachinePointerInfo MachinePointerInfo::getJumpTable ( MachineFunction MF)
static

◆ getStack()

MachinePointerInfo MachinePointerInfo::getStack ( MachineFunction MF,
int64_t  Offset,
uint8_t  ID = 0 
)
static

◆ getUnknownStack()

MachinePointerInfo MachinePointerInfo::getUnknownStack ( MachineFunction MF)
static

Stack memory without other information.

Definition at line 982 of file MachineOperand.cpp.

References llvm::DataLayout::getAllocaAddrSpace(), and llvm::MachineFunction::getDataLayout().

Referenced by findUnwindDestinations(), and getWithOffset().

◆ getWithOffset()

MachinePointerInfo llvm::MachinePointerInfo::getWithOffset ( int64_t  O) const
inline

◆ isDereferenceable()

bool MachinePointerInfo::isDereferenceable ( unsigned  Size,
LLVMContext C,
const DataLayout DL 
) const

Return true if memory region [V, V+Offset+Size) is known to be dereferenceable.

isDereferenceable - Return true if V is always dereferenceable for Offset + Size byte.

Definition at line 943 of file MachineOperand.cpp.

References llvm::DataLayout::getPointerSizeInBits(), llvm::isDereferenceableAndAlignedPointer(), and Size.

Referenced by getMemcpyLoadsAndStores(), getMemmoveLoadsAndStores(), and getWithOffset().

Member Data Documentation

◆ AddrSpace

unsigned llvm::MachinePointerInfo::AddrSpace = 0

Definition at line 50 of file MachineMemOperand.h.

◆ Offset

int64_t llvm::MachinePointerInfo::Offset

Offset - This is an offset from the base Value*.

Definition at line 46 of file MachineMemOperand.h.

Referenced by llvm::MachineMemOperand::getOffset(), and llvm::MachineMemOperand::setOffset().

◆ StackID

uint8_t llvm::MachinePointerInfo::StackID

Definition at line 48 of file MachineMemOperand.h.

Referenced by getWithOffset().

◆ V

PointerUnion<const Value *, const PseudoSourceValue *> llvm::MachinePointerInfo::V

The documentation for this struct was generated from the following files: