34 const unsigned *Indices,
35 const unsigned *IndicesEnd,
38 if (Indices && Indices == IndicesEnd)
45 if (Indices && *Indices ==
I.index())
49 assert(!Indices &&
"Unexpected out of bound");
54 Type *EltTy = ATy->getElementType();
55 unsigned NumElts = ATy->getNumElements();
59 assert(*Indices < NumElts &&
"Unexpected out of bound");
62 CurIndex += EltLinearOffset* *Indices;
65 CurIndex += EltLinearOffset*NumElts;
77 StartingOffset.
isZero()) &&
78 "Offset/TypeSize mismatch!");
84 const StructLayout *SL = Offsets ?
DL.getStructLayout(STy) :
nullptr;
86 EE = STy->element_end();
97 Type *EltTy = ATy->getElementType();
99 for (
unsigned i = 0, e = ATy->getNumElements(); i != e; ++i)
101 StartingOffset + i * EltSize);
109 Offsets->push_back(StartingOffset);
126 ValueVTs.
reserve(Types.size());
129 for (
Type *Ty : Types) {
145 FixedOffsets->
reserve(Offsets.size());
160 for (
Type *ValTy : ValTys)
172 FixedOffsets->
reserve(Offsets.size());
186 if (Var && Var->
getName() ==
"llvm.eh.catch.all.value") {
188 "The EH catch-all value must have an initializer");
195 "TypeInfo must be a global variable or NULL");
283 return T1 == T2 || (
T1->isPointerTy() && T2->isPointerTy()) ||
308 if (!
I ||
I->getNumOperands() == 0)
return V;
309 const Value *NoopInput =
nullptr;
325 DL.getPointerSizeInBits() ==
333 DL.getPointerSizeInBits() ==
340 I->getType()->getPrimitiveSizeInBits().getFixedValue());
343 const Value *ReturnedOp = CB->getReturnedArgOperand();
345 NoopInput = ReturnedOp;
349 if (ValLoc.
size() >= InsertLoc.
size() &&
350 std::equal(InsertLoc.
begin(), InsertLoc.
end(), ValLoc.
rbegin())) {
355 NoopInput = IVI->getInsertedValueOperand();
384 bool AllowDifferingSizes,
392 unsigned BitsRequired = UINT_MAX;
404 unsigned BitsProvided = UINT_MAX;
405 CallVal =
getNoopInput(CallVal, CallIndices, BitsProvided, TLI,
DL);
409 if (CallVal != RetVal || CallIndices != RetIndices)
416 if (BitsProvided < BitsRequired ||
417 (!AllowDifferingSizes && BitsProvided != BitsRequired))
427 return Idx < AT->getNumElements();
429 return Idx < cast<StructType>(
T)->getNumElements();
509 ->isAggregateType()) {
525 assert(!Path.empty() &&
"found a leaf but didn't set the path?");
527 ->isAggregateType());
540 bool ReturnsFirstArg) {
567 if (BBI->isDebugOrPseudoInst())
572 if (
II->getIntrinsicID() == Intrinsic::lifetime_end ||
573 II->getIntrinsicID() == Intrinsic::assume ||
574 II->getIntrinsicID() == Intrinsic::experimental_noalias_scope_decl ||
575 II->getIntrinsicID() == Intrinsic::fake_use)
577 if (BBI->mayHaveSideEffects() || BBI->mayReadFromMemory() ||
591 bool *AllowDifferingSizes) {
594 bool &ADS = AllowDifferingSizes ? *AllowDifferingSizes : DummyADS;
597 AttrBuilder CallerAttrs(
F->getContext(),
F->getAttributes().getRetAttrs());
598 AttrBuilder CalleeAttrs(
F->getContext(),
603 for (
const auto &Attr : {Attribute::Alignment, Attribute::Dereferenceable,
604 Attribute::DereferenceableOrNull, Attribute::NoAlias,
605 Attribute::NonNull, Attribute::NoUndef,
606 Attribute::Range, Attribute::NoFPClass}) {
607 CallerAttrs.removeAttribute(Attr);
608 CalleeAttrs.removeAttribute(Attr);
611 if (CallerAttrs.contains(Attribute::ZExt)) {
612 if (!CalleeAttrs.contains(Attribute::ZExt))
616 CallerAttrs.removeAttribute(Attribute::ZExt);
617 CalleeAttrs.removeAttribute(Attribute::ZExt);
618 }
else if (CallerAttrs.contains(Attribute::SExt)) {
619 if (!CalleeAttrs.contains(Attribute::SExt))
623 CallerAttrs.removeAttribute(Attribute::SExt);
624 CalleeAttrs.removeAttribute(Attribute::SExt);
637 if (
I->use_empty()) {
638 CalleeAttrs.removeAttribute(Attribute::SExt);
639 CalleeAttrs.removeAttribute(Attribute::ZExt);
645 return CallerAttrs == CalleeAttrs;
652 bool ReturnsFirstArg) {
662 bool AllowDifferingSizes;
675 bool CallEmpty = !
firstRealType(CallVal->getType(), CallSubTypes, CallPath);
709 AllowDifferingSizes, TLI,
722 bool ReturnsFirstArg =
false;
724 ReturnsFirstArg =
true;
725 return ReturnsFirstArg;
732 while (!Worklist.
empty()) {
739 auto P = EHScopeMembership.
insert(std::make_pair(Visiting, EHScope));
743 assert(
P.first->second == EHScope &&
"MBB is part of two scopes!");
762 return EHScopeMembership;
774 if (
MBB.isEHScopeEntry()) {
776 }
else if (IsSEH &&
MBB.isEHPad()) {
778 }
else if (
MBB.pred_empty()) {
786 if (
MBBI ==
MBB.end() ||
MBBI->getOpcode() !=
TII->getCatchReturnOpcode())
798 if (EHScopeBlocks.
empty())
799 return EHScopeMembership;
813 for (std::pair<const MachineBasicBlock *, int> CatchRetPair :
817 return EHScopeMembership;
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
MachineBasicBlock MachineBasicBlock::iterator MBBI
static bool isNoopBitcast(Type *T1, Type *T2, const TargetLoweringBase &TLI)
static bool firstRealType(Type *Next, SmallVectorImpl< Type * > &SubTypes, SmallVectorImpl< unsigned > &Path)
Find the first non-empty, scalar-like type in Next and setup the iterator components.
static bool slotOnlyDiscardsData(const Value *RetVal, const Value *CallVal, SmallVectorImpl< unsigned > &RetIndices, SmallVectorImpl< unsigned > &CallIndices, bool AllowDifferingSizes, const TargetLoweringBase &TLI, const DataLayout &DL)
Return true if this scalar return value only has bits discarded on its path from the "tail call" to t...
static void collectEHScopeMembers(DenseMap< const MachineBasicBlock *, int > &EHScopeMembership, int EHScope, const MachineBasicBlock *MBB)
static bool indexReallyValid(Type *T, unsigned Idx)
For an aggregate type, determine whether a given index is within bounds or not.
static bool nextRealType(SmallVectorImpl< Type * > &SubTypes, SmallVectorImpl< unsigned > &Path)
Set the iterator data-structures to the next non-empty, non-aggregate subtype.
static bool advanceToNextLeafType(SmallVectorImpl< Type * > &SubTypes, SmallVectorImpl< unsigned > &Path)
Move the given iterators to the next leaf type in depth first traversal.
static const Value * getNoopInput(const Value *V, SmallVectorImpl< unsigned > &ValLoc, unsigned &DataBits, const TargetLoweringBase &TLI, const DataLayout &DL)
Look through operations that will be free to find the earliest source of this value.
const HexagonInstrInfo * TII
Module.h This file contains the declarations for the Module class.
uint64_t IntrinsicInst * II
This file describes how to lower LLVM code to machine code.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
reverse_iterator rend() const
size_t size() const
size - Get the array size.
reverse_iterator rbegin() const
Class to represent array types.
LLVM Basic Block Representation.
const Function * getParent() const
Return the enclosing method, or null if none.
InstListType::const_iterator const_iterator
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction if the block is well formed or null if the block is not well forme...
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
Value * getArgOperand(unsigned i) const
This class represents a function call, abstracting a target machine's calling convention.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
@ FCMP_OEQ
0 0 0 1 True if ordered and equal
@ FCMP_TRUE
1 1 1 1 Always true (always folded)
@ ICMP_SLT
signed less than
@ ICMP_SLE
signed less or equal
@ FCMP_OLT
0 1 0 0 True if ordered and less than
@ FCMP_ULE
1 1 0 1 True if unordered, less than, or equal
@ FCMP_OGT
0 0 1 0 True if ordered and greater than
@ FCMP_OGE
0 0 1 1 True if ordered and greater than or equal
@ ICMP_UGE
unsigned greater or equal
@ ICMP_UGT
unsigned greater than
@ ICMP_SGT
signed greater than
@ FCMP_ULT
1 1 0 0 True if unordered or less than
@ FCMP_ONE
0 1 1 0 True if ordered and operands are unequal
@ FCMP_UEQ
1 0 0 1 True if unordered or equal
@ ICMP_ULT
unsigned less than
@ FCMP_UGT
1 0 1 0 True if unordered or greater than
@ FCMP_OLE
0 1 0 1 True if ordered and less than or equal
@ FCMP_ORD
0 1 1 1 True if ordered (no nans)
@ ICMP_SGE
signed greater or equal
@ FCMP_UNE
1 1 1 0 True if unordered or not equal
@ ICMP_ULE
unsigned less or equal
@ FCMP_UGE
1 0 1 1 True if unordered, greater than, or equal
@ FCMP_FALSE
0 0 0 0 Always false (always folded)
@ FCMP_UNO
1 0 0 0 True if unordered: isnan(X) | isnan(Y)
const Constant * stripPointerCasts() const
A parsed version of the target data layout string in and methods for querying it.
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Constant * getPersonalityFn() const
Get the personality function associated with this function.
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
bool hasInitializer() const
Definitions have initializers, declarations don't.
This instruction inserts a struct field of array element value into an aggregate value.
A wrapper class for inspecting calls to intrinsic functions.
bool isEHPad() const
Returns true if the block is a landing pad.
MachineInstrBundleIterator< const MachineInstr > const_iterator
int getNumber() const
MachineBasicBlocks are uniquely numbered at the function level, unless they're not in a MachineFuncti...
iterator_range< succ_iterator > successors()
bool isEHScopeReturnBlock() const
Convenience function that returns true if the bock ends in a EH scope return instruction.
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
Function & getFunction()
Return the LLVM function that this machine code represents.
const MachineBasicBlock & front() const
Return a value (possibly void), from a function.
Value * getReturnValue() const
Convenience accessor. Returns null if there is no return value.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void reserve(size_type N)
void append(ItTy in_start, ItTy in_end)
Add the specified range to the end of the SmallVector.
void push_back(const T &Elt)
reverse_iterator rbegin()
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Used to lazily calculate structure layout information for a target machine, based on the DataLayout s...
TypeSize getElementOffset(unsigned Idx) const
Class to represent struct types.
Type::subtype_iterator element_iterator
TargetInstrInfo - Interface to description of machine instruction set.
This base class for TargetLowering contains the SelectionDAG-independent parts that can be used from ...
EVT getMemValueType(const DataLayout &DL, Type *Ty, bool AllowUnknown=false) const
EVT getValueType(const DataLayout &DL, Type *Ty, bool AllowUnknown=false) const
Return the EVT corresponding to this LLVM type.
virtual bool allowTruncateForTailCall(Type *FromTy, Type *ToTy) const
Return true if a truncation from FromTy to ToTy is permitted when deciding whether a call is in tail ...
bool isTypeLegal(EVT VT) const
Return true if the target has native support for the specified value type.
This class defines information used to lower LLVM code to legal SelectionDAG operators that the targe...
Primary interface to the complete machine description for the target machine.
virtual const TargetSubtargetInfo * getSubtargetImpl(const Function &) const
Virtual method implemented by subclasses that returns a reference to that target's TargetSubtargetInf...
unsigned GuaranteedTailCallOpt
GuaranteedTailCallOpt - This flag is enabled when -tailcallopt is specified on the commandline.
virtual const TargetInstrInfo * getInstrInfo() const
virtual const TargetLowering * getTargetLowering() const
static constexpr TypeSize getFixed(ScalarTy ExactSize)
static constexpr TypeSize getZero()
The instances of the Type class are immutable: once they are created, they are never changed.
bool isAggregateType() const
Return true if the type is an aggregate type.
static LLVM_ABI UndefValue * get(Type *T)
Static factory methods - Return an 'undef' object of the specified type.
Value * getOperand(unsigned i) const
unsigned getNumOperands() const
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
constexpr bool isScalable() const
Returns whether the quantity is scaled by a runtime quantity (vscale).
constexpr bool isZero() const
const ParentTy * getParent() const
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
CondCode
ISD::CondCode enum - These are ordered carefully to make the bitfields below work out,...
This is an optimization pass for GlobalISel generic memory operations.
ISD::CondCode getICmpCondCode(ICmpInst::Predicate Pred)
getICmpCondCode - Return the ISD condition code corresponding to the given LLVM IR integer condition ...
void ComputeValueVTs(const TargetLowering &TLI, const DataLayout &DL, Type *Ty, SmallVectorImpl< EVT > &ValueVTs, SmallVectorImpl< EVT > *MemVTs=nullptr, SmallVectorImpl< TypeSize > *Offsets=nullptr, TypeSize StartingOffset=TypeSize::getZero())
ComputeValueVTs - Given an LLVM IR type, compute a sequence of EVTs that represent all the individual...
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
void append_range(Container &C, Range &&R)
Wrapper function to append range R to container C.
LLVM_ABI bool isSafeToSpeculativelyExecute(const Instruction *I, const Instruction *CtxI=nullptr, AssumptionCache *AC=nullptr, const DominatorTree *DT=nullptr, const TargetLibraryInfo *TLI=nullptr, bool UseVariableInfo=true, bool IgnoreUBImplyingAttrs=true)
Return true if the instruction does not have any effects besides calculating the result and does not ...
void ComputeValueTypes(const DataLayout &DL, Type *Ty, SmallVectorImpl< Type * > &Types, SmallVectorImpl< TypeSize > *Offsets=nullptr, TypeSize StartingOffset=TypeSize::getZero())
Given an LLVM IR type, compute non-aggregate subtypes.
auto reverse(ContainerTy &&C)
bool returnTypeIsEligibleForTailCall(const Function *F, const Instruction *I, const ReturnInst *Ret, const TargetLoweringBase &TLI, bool ReturnsFirstArg=false)
Test if given that the input instruction is in the tail call position if the return type or any attri...
ISD::CondCode getFCmpCondCode(FCmpInst::Predicate Pred)
getFCmpCondCode - Return the ISD condition code corresponding to the given LLVM IR floating-point con...
LLVM_ABI EHPersonality classifyEHPersonality(const Value *Pers)
See if the given exception handling personality function is one that we understand.
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
bool attributesPermitTailCall(const Function *F, const Instruction *I, const ReturnInst *Ret, const TargetLoweringBase &TLI, bool *AllowDifferingSizes=nullptr)
Test if given that the input instruction is in the tail call position, if there is an attribute misma...
FunctionAddr VTableAddr Next
bool isInTailCallPosition(const CallBase &Call, const TargetMachine &TM, bool ReturnsFirstArg=false)
Test if the given instruction is in a position to be optimized with a tail-call.
DWARFExpression::Operation Op
ISD::CondCode getFCmpCodeWithoutNaN(ISD::CondCode CC)
getFCmpCodeWithoutNaN - Given an ISD condition code comparing floats, return the equivalent code if w...
bool isAsynchronousEHPersonality(EHPersonality Pers)
Returns true if this personality function catches asynchronous exceptions.
bool funcReturnsFirstArgOfCall(const CallInst &CI)
Returns true if the parent of CI returns CI's first argument after calling CI.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
void computeValueLLTs(const DataLayout &DL, Type &Ty, SmallVectorImpl< LLT > &ValueLLTs, SmallVectorImpl< TypeSize > *Offsets=nullptr, TypeSize StartingOffset=TypeSize::getZero())
computeValueLLTs - Given an LLVM IR type, compute a sequence of LLTs that represent all the individua...
GlobalValue * ExtractTypeInfo(Value *V)
ExtractTypeInfo - Returns the type info, possibly bitcast, encoded in V.
unsigned ComputeLinearIndex(Type *Ty, const unsigned *Indices, const unsigned *IndicesEnd, unsigned CurIndex=0)
Compute the linearized index of a member in a nested aggregate/struct/array.
DenseMap< const MachineBasicBlock *, int > getEHScopeMembership(const MachineFunction &MF)
LLVM_ABI LLT getLLTForType(Type &Ty, const DataLayout &DL)
Construct a low-level type based on an LLVM type.
static LLVM_ABI EVT getEVT(Type *Ty, bool HandleUnknown=false)
Return the value type corresponding to the specified type.