LLVM
8.0.1
|
Implementation of non-dependent functionality for PtrUseVisitor
.
More...
#include "llvm/Analysis/PtrUseVisitor.h"
Classes | |
class | PtrInfo |
This class provides information about the result of a visit. More... | |
struct | UseToVisit |
A struct of the data needed to visit a particular use. More... | |
Protected Member Functions | |
PtrUseVisitorBase (const DataLayout &DL) | |
Note that the constructor is protected because this class must be a base class, we can't create instances directly of this class. More... | |
void | enqueueUsers (Instruction &I) |
Enqueue the users of this instruction in the visit worklist. More... | |
bool | adjustOffsetForGEP (GetElementPtrInst &GEPI) |
Walk the operands of a GEP and adjust the offset as appropriate. More... | |
Protected Attributes | |
const DataLayout & | DL |
Visitation infrastructure | |
PtrInfo | PI |
The info collected about the pointer being visited thus far. More... | |
SmallVector< UseToVisit, 8 > | Worklist |
The worklist of to-visit uses. More... | |
SmallPtrSet< Use *, 8 > | VisitedUses |
A set of visited uses to break cycles in unreachable code. More... | |
Per-visit state | |
This state is reset for each instruction visited. | |
Use * | U |
The use currently being visited. More... | |
bool | IsOffsetKnown |
True if we have a known constant offset for the use currently being visited. More... | |
APInt | Offset |
The constant offset of the use if that is known. More... | |
Implementation of non-dependent functionality for PtrUseVisitor
.
See PtrUseVisitor
for the public interface and detailed comments about usage. This class is just a helper base class which is not templated and contains all common code to be shared between different instantiations of PtrUseVisitor.
Definition at line 56 of file PtrUseVisitor.h.
|
inlineprotected |
Note that the constructor is protected because this class must be a base class, we can't create instances directly of this class.
Definition at line 164 of file PtrUseVisitor.h.
References adjustOffsetForGEP(), enqueueUsers(), and I.
|
protected |
Walk the operands of a GEP and adjust the offset as appropriate.
This routine does the heavy lifting of the pointer walk by computing offsets and looking through GEPs.
Definition at line 34 of file PtrUseVisitor.cpp.
References llvm::GetElementPtrInst::accumulateConstantOffset(), DL, IsOffsetKnown, and Offset.
Referenced by PtrUseVisitorBase(), and llvm::PtrUseVisitor< SliceBuilder >::visitGetElementPtrInst().
|
protected |
Enqueue the users of this instruction in the visit worklist.
This will visit the users with the same offset of the current visit (including an unknown offset if that is the current state).
Definition at line 22 of file PtrUseVisitor.cpp.
References IsOffsetKnown, Offset, U, llvm::Value::uses(), VisitedUses, and Worklist.
Referenced by PtrUseVisitorBase(), llvm::PtrUseVisitor< SliceBuilder >::visitBitCastInst(), llvm::PtrUseVisitor< SliceBuilder >::visitGetElementPtrInst(), and llvm::PtrUseVisitor< SliceBuilder >::visitPtr().
|
protected |
Definition at line 119 of file PtrUseVisitor.h.
Referenced by adjustOffsetForGEP(), and llvm::PtrUseVisitor< SliceBuilder >::visitPtr().
|
protected |
True if we have a known constant offset for the use currently being visited.
Definition at line 155 of file PtrUseVisitor.h.
Referenced by adjustOffsetForGEP(), enqueueUsers(), llvm::PtrUseVisitor< SliceBuilder >::visitGetElementPtrInst(), and llvm::PtrUseVisitor< SliceBuilder >::visitPtr().
|
protected |
The constant offset of the use if that is known.
Definition at line 158 of file PtrUseVisitor.h.
Referenced by adjustOffsetForGEP(), enqueueUsers(), llvm::PtrUseVisitor< SliceBuilder >::visitGetElementPtrInst(), and llvm::PtrUseVisitor< SliceBuilder >::visitPtr().
|
protected |
The info collected about the pointer being visited thus far.
Definition at line 125 of file PtrUseVisitor.h.
Referenced by llvm::PtrUseVisitor< SliceBuilder >::visitCallSite(), llvm::PtrUseVisitor< SliceBuilder >::visitPtr(), llvm::PtrUseVisitor< SliceBuilder >::visitPtrToIntInst(), and llvm::PtrUseVisitor< SliceBuilder >::visitStoreInst().
|
protected |
The use currently being visited.
Definition at line 151 of file PtrUseVisitor.h.
Referenced by enqueueUsers(), llvm::PtrUseVisitor< SliceBuilder >::visitPtr(), and llvm::PtrUseVisitor< SliceBuilder >::visitStoreInst().
|
protected |
A set of visited uses to break cycles in unreachable code.
Definition at line 142 of file PtrUseVisitor.h.
Referenced by enqueueUsers().
|
protected |
The worklist of to-visit uses.
Definition at line 139 of file PtrUseVisitor.h.
Referenced by enqueueUsers(), and llvm::PtrUseVisitor< SliceBuilder >::visitPtr().