15#ifndef LLVM_TRANSFORMS_SCALAR_GVN_H
16#define LLVM_TRANSFORMS_SCALAR_GVN_H
144 function_ref<StringRef(StringRef)> MapClassName2PassName);
174 std::vector<Expression> Expressions;
175 std::vector<uint32_t> ExprIdx;
185 using PhiTranslateMap =
187 PhiTranslateMap PhiTranslateTable;
191 bool IsMDEnabled =
false;
193 bool IsMSSAEnabled =
false;
209 std::pair<uint32_t, bool> assignExpNewValueNum(
Expression &Exp);
238 IsMDEnabled = MDEnabled;
242 IsMSSAEnabled = MSSAEnabled;
280 struct LeaderListNode {
281 LeaderTableEntry Entry;
282 LeaderListNode *
Next;
286 DenseMap<uint32_t, LeaderListNode> NumToLeaders;
291 const LeaderListNode *Current;
302 assert(Current &&
"Dereferenced end of leader list!");
303 Current = Current->Next;
307 return Current == Other.Current;
310 return Current != Other.Current;
316 auto I = NumToLeaders.find(
N);
317 if (
I == NumToLeaders.end()) {
319 leader_iterator(
nullptr));
323 leader_iterator(
nullptr));
332 for (
auto &[
_, HeadNode] : NumToLeaders) {
333 LeaderListNode *
N = HeadNode.Next;
335 auto *
Next =
N->Next;
336 N->~LeaderListNode();
340 NumToLeaders.clear();
341 TableAllocator.Reset();
344 LeaderMap LeaderTable;
348 DenseMap<AssertingVH<BasicBlock>, uint32_t> BlockRPONumber;
353 bool InvalidBlockRPONumbers =
true;
355 using LoadDepVect = SmallVector<NonLocalDepResult, 64>;
356 using AvailValInBlkVect = SmallVector<gvn::AvailableValueInBlock, 64>;
357 using UnavailBlkVect = SmallVector<BasicBlock *, 64>;
359 bool runImpl(Function &
F, AssumptionCache &RunAC, DominatorTree &RunDT,
360 const TargetLibraryInfo &RunTLI, AAResults &RunAA,
361 MemoryDependenceResults *RunMD, LoopInfo &LI,
362 OptimizationRemarkEmitter *ORE,
MemorySSA *MSSA =
nullptr);
375 struct ReachingMemVal {
382 static ReachingMemVal getUnknown(BasicBlock *BB,
const Value *Addr,
383 Instruction *Inst =
nullptr) {
384 return {DepKind::Other, BB, Addr, Inst, -1};
387 static ReachingMemVal getDef(
const Value *Addr, Instruction *Inst) {
388 return {DepKind::Def, Inst->getParent(), Addr, Inst, -1};
391 static ReachingMemVal getClobber(
const Value *Addr, Instruction *Inst,
392 int32_t Offset = -1) {
393 return {DepKind::Clobber, Inst->getParent(), Addr, Inst, Offset};
397 struct DependencyBlockInfo {
398 DependencyBlockInfo() =
delete;
399 DependencyBlockInfo(
const PHITransAddr &Addr, MemoryAccess *ClobberMA)
400 : Addr(Addr), InitialClobberMA(ClobberMA), ClobberMA(ClobberMA),
403 MemoryAccess *InitialClobberMA;
404 MemoryAccess *ClobberMA;
405 std::optional<ReachingMemVal> MemVal;
406 bool ForceUnknown : 1;
410 using DependencyBlockSet = DenseMap<BasicBlock *, DependencyBlockInfo>;
412 std::optional<GVNPass::ReachingMemVal> scanMemoryAccessesUsers(
413 const MemoryLocation &Loc,
bool IsInvariantLoad, BasicBlock *BB,
414 const SmallVectorImpl<MemoryAccess *> &ClobbersList,
MemorySSA &MSSA,
415 BatchAAResults &AA, LoadInst *L =
nullptr);
417 std::optional<GVNPass::ReachingMemVal>
418 accessMayModifyLocation(MemoryAccess *ClobberMA,
const MemoryLocation &Loc,
419 bool IsInvariantLoad, BasicBlock *BB,
MemorySSA &MSSA,
422 bool collectPredecessors(BasicBlock *BB,
const PHITransAddr &Addr,
423 MemoryAccess *ClobberMA, DependencyBlockSet &Blocks,
424 SmallVectorImpl<BasicBlock *> &Worklist);
426 void collectClobberList(SmallVectorImpl<MemoryAccess *> &Clobbers,
427 BasicBlock *BB,
const DependencyBlockInfo &StartInfo,
428 const DependencyBlockSet &Blocks,
MemorySSA &MSSA);
430 bool findReachingValuesForLoad(LoadInst *Inst,
431 SmallVectorImpl<ReachingMemVal> &Values,
435 bool processLoad(LoadInst *L);
436 bool processMaskedLoad(IntrinsicInst *
I);
437 bool processNonLocalLoad(LoadInst *L);
438 bool processNonLocalLoad(LoadInst *L, SmallVectorImpl<ReachingMemVal> &Deps);
439 bool processAssumeIntrinsic(AssumeInst *
II);
443 std::optional<gvn::AvailableValue>
444 AnalyzeLoadAvailability(LoadInst *Load,
const ReachingMemVal &Dep,
450 void AnalyzeLoadAvailability(LoadInst *Load,
451 SmallVectorImpl<ReachingMemVal> &Deps,
452 AvailValInBlkVect &ValuesPerBlock,
453 UnavailBlkVect &UnavailableBlocks);
457 LoadInst *findLoadToHoistIntoPred(BasicBlock *Pred, BasicBlock *LoadBB,
460 bool PerformLoadPRE(LoadInst *Load, AvailValInBlkVect &ValuesPerBlock,
461 UnavailBlkVect &UnavailableBlocks);
466 bool performLoopLoadPRE(LoadInst *Load, AvailValInBlkVect &ValuesPerBlock,
467 UnavailBlkVect &UnavailableBlocks);
471 void eliminatePartiallyRedundantLoad(
472 LoadInst *Load, AvailValInBlkVect &ValuesPerBlock,
473 MapVector<BasicBlock *, Value *> &AvailableLoads,
474 MapVector<BasicBlock *, LoadInst *> *CriticalEdgePredAndLoad);
477 bool processInstruction(Instruction *
I);
478 bool processBlock(BasicBlock *BB);
479 void dump(DenseMap<uint32_t, Value *> &Map)
const;
480 bool iterateOnFunction(Function &
F);
481 bool performPRE(Function &
F);
482 bool performScalarPRE(Instruction *
I);
483 bool performScalarPREInsertion(Instruction *Instr, BasicBlock *Pred,
484 BasicBlock *Curr,
unsigned int ValNo);
485 Value *findLeader(
const BasicBlock *BB, uint32_t Num);
486 void cleanupGlobalSets();
487 void removeInstruction(Instruction *
I);
488 void verifyRemoved(
const Instruction *
I)
const;
489 bool splitCriticalEdges();
490 BasicBlock *splitCriticalEdges(BasicBlock *Pred, BasicBlock *Succ);
493 const std::variant<BasicBlockEdge, Instruction *> &Root);
494 bool processFoldableCondBr(CondBrInst *BI);
495 void addDeadBlock(BasicBlock *BB);
496 void assignValNumForDeadCode();
497 void assignBlockRPONumber(Function &
F);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
Function Alias Analysis false
This file defines the BumpPtrAllocator interface.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
#define LLVM_LIBRARY_VISIBILITY_NAMESPACE
This file defines the DenseMap class.
early cse Early CSE w MemorySSA
This header defines various interfaces for pass management in LLVM.
This file implements a map that provides insertion order iteration.
uint64_t IntrinsicInst * II
ppc ctr loops PowerPC CTR Loops Verify
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallVector class.
Value handle that asserts if the Value is deleted.
This represents the llvm.assume intrinsic.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
This class is a wrapper over an AAResults, and it is intended to be used only when there are no IR ch...
This class represents a function call, abstracting a target machine's calling convention.
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Conditional Branch instruction.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Context-sensitive CaptureAnalysis provider, which computes and caches the earliest common dominator c...
FunctionPass class - This class is used to implement most global optimizations.
const LeaderTableEntry value_type
std::forward_iterator_tag iterator_category
bool operator==(const leader_iterator &Other) const
bool operator!=(const leader_iterator &Other) const
leader_iterator(const LeaderListNode *C)
leader_iterator & operator++()
std::ptrdiff_t difference_type
reference operator*() const
This class holds the mapping between values and value numbers.
void setMemDep(MemoryDependenceResults *M, bool MDEnabled=true)
LLVM_ABI ValueTable(ValueTable &&Arg)
void setMemorySSA(MemorySSA *M, bool MSSAEnabled=false)
LLVM_ABI uint32_t lookupOrAddCmp(unsigned Opcode, CmpInst::Predicate Pred, Value *LHS, Value *RHS)
Returns the value number of the given comparison, assigning it a new number if it did not have one be...
uint32_t getNextUnusedValueNumber()
LLVM_ABI uint32_t lookup(Value *V, bool Verify=true) const
Returns the value number of the specified value.
LLVM_ABI ValueTable & operator=(const ValueTable &Arg)
void setAliasAnalysis(AAResults *A)
LLVM_ABI void add(Value *V, uint32_t Num)
add - Insert a value into the table with a specified value number.
LLVM_ABI void clear()
Remove all entries from the ValueTable.
LLVM_ABI bool exists(Value *V) const
Returns true if a value number exists for the specified value.
LLVM_ABI ValueTable(const ValueTable &Arg)
LLVM_ABI uint32_t lookupOrAdd(MemoryAccess *MA)
AAResults * getAliasAnalysis() const
LLVM_ABI uint32_t phiTranslate(const BasicBlock *BB, const BasicBlock *PhiBlock, uint32_t Num, GVNPass &GVN)
Wrap phiTranslateImpl to provide caching functionality.
void setDomTree(DominatorTree *D)
LLVM_ABI void eraseTranslateCacheEntry(uint32_t Num, const BasicBlock &CurrBlock)
Erase stale entry from phiTranslate cache so phiTranslate can be computed again.
LLVM_ABI void erase(Value *V)
Remove a value from the value numbering.
LLVM_ABI void verifyRemoved(const Value *) const
verifyRemoved - Verify that the value is removed from all internal data structures.
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Run the pass over the function.
LLVM_ABI void salvageAndRemoveInstruction(Instruction *I)
This removes the specified instruction from our various maps and marks it for deletion.
AAResults * getAliasAnalysis() const
LLVM_ABI bool isLoadPREEnabled() const
GVNPass(GVNOptions Options={})
LLVM_ABI void printPipeline(raw_ostream &OS, function_ref< StringRef(StringRef)> MapClassName2PassName)
LLVM_ABI bool isMemorySSAEnabled() const
DominatorTree & getDominatorTree() const
LLVM_ABI bool isLoadInLoopPREEnabled() const
LLVM_ABI bool isScalarPREEnabled() const
LLVM_ABI bool isLoadPRESplitBackedgeEnabled() const
LLVM_ABI bool isMemDepEnabled() const
MemoryDependenceResults & getMemDep() const
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
This class allows to keep track on instructions with implicit control flow.
A wrapper class for inspecting calls to intrinsic functions.
An instruction for reading from memory.
A memory dependence query can return one of three different answers.
Provides a lazy, caching interface for making common memory aliasing information queries,...
Representation for a specific memory location.
Encapsulates MemorySSA, including all data associated with memory accesses.
This is a result from a NonLocal dependence query.
A set of analyses that are preserved following a run of a transformation pass.
A vector that has set insertion semantics.
Provides information about what library functions are available for the current target.
LLVM Value Representation.
A range adaptor for a pair of iterators.
@ C
The default llvm calling convention, compatible with C.
@ BasicBlock
Various leaf nodes.
A private "module" namespace for types and utilities used by GVN.
friend class Instruction
Iterator for Instructions in a `BasicBlock.
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
iterator_range(Container &&) -> iterator_range< llvm::detail::IterOfRange< Container > >
LLVM_ABI FunctionPass * createGVNPass()
FunctionAddr VTableAddr Next
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
BumpPtrAllocatorImpl<> BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
An information struct used to provide DenseMap with the various necessary components for a given valu...
A simple and fast domtree-based GVN pass to hoist common expressions from sibling branches.
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Run the pass over the function.
A set of parameters to control various transforms performed by GVN pass.
GVNOptions & setLoadPRE(bool LoadPRE)
Enables or disables PRE of loads in GVN.
std::optional< bool > AllowLoadPRESplitBackedge
std::optional< bool > AllowScalarPRE
GVNOptions & setLoadInLoopPRE(bool LoadInLoopPRE)
std::optional< bool > AllowLoadInLoopPRE
std::optional< bool > AllowMemDep
GVNOptions & setMemDep(bool MemDep)
Enables or disables use of MemDepAnalysis.
GVNOptions & setScalarPRE(bool ScalarPRE)
Enables or disables PRE of scalars in GVN.
std::optional< bool > AllowLoadPRE
GVNOptions & setLoadPRESplitBackedge(bool LoadPRESplitBackedge)
Enables or disables PRE of loads in GVN.
std::optional< bool > AllowMemorySSA
GVNOptions & setMemorySSA(bool MemSSA)
Enables or disables use of MemorySSA.
LeaderTableEntry(Value *V, const BasicBlock *BB)
Uses an "inverted" value numbering to decide the similarity of expressions and sinks similar expressi...
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
Run the pass over the function.
A CRTP mix-in for passes that can be skipped.
Represents an AvailableValue which can be rematerialized at the end of the associated BasicBlock.
Represents a particular available value that we know how to materialize.