41 cl::desc(
"Enable verification of assumption cache"),
45AssumptionCache::getOrInsertAffectedValues(
Value *V) {
48 auto AVI = AffectedValues.find_as(V);
49 if (AVI != AffectedValues.end())
52 return AffectedValues[AffectedValueCallbackVH(V,
this)];
57 auto AddAffectedVal = [&](
Value *V) {
62 if (Bundle.
getTagName() ==
"separate_storage") {
63 assert(Bundle.
Inputs.size() == 2 &&
"separate_storage must have two args");
77 auto InsertAffected = [&Affected](
Value *V) {
81 auto AddAffectedVal = [&Affected](
Value *V,
unsigned Idx) {
90 [&](
Value *V) { Affected.push_back({V, Idx}); });
98 std::tie(
Ptr, AS) =
TTI->getPredicatedAddrSpace(
Cond);
100 AddAffectedVal(
const_cast<Value *
>(
Ptr->stripInBoundsOffsets()),
109 for (
auto &AV : Affected) {
110 auto &AVV = getOrInsertAffectedValues(AV.Assume);
112 return Elem.
Assume == CI && Elem.
Index == AV.Index;
114 AVV.push_back({CI, AV.Index});
122 for (
auto &AV : Affected) {
123 auto AVI = AffectedValues.find_as(AV.Assume);
124 if (AVI == AffectedValues.end())
127 bool HasNonnull =
false;
133 HasNonnull |= !!Elem.
Assume;
134 if (HasNonnull && Found)
137 assert(Found &&
"already unregistered or incorrect cache state");
139 AffectedValues.erase(AVI);
150void AssumptionCache::transferAffectedValuesInCache(
Value *OV,
Value *NV) {
151 auto &NAVV = getOrInsertAffectedValues(NV);
152 auto AVI = AffectedValues.find(OV);
153 if (AVI == AffectedValues.end())
156 for (
auto &
A : AVI->second)
159 AffectedValues.erase(OV);
162void AssumptionCache::AffectedValueCallbackVH::allUsesReplacedWith(
Value *NV) {
168 AC->transferAffectedValuesInCache(getValPtr(), NV);
174void AssumptionCache::scanFunction() {
175 assert(!Scanned &&
"Tried to scan the function twice!");
176 assert(AssumeHandles.empty() &&
"Already have assumes when scanning!");
180 for (BasicBlock &
B : F)
181 for (Instruction &
I :
B)
183 AssumeHandles.push_back(&
I);
189 for (
auto &
A : AssumeHandles)
199 AssumeHandles.push_back(CI);
203 "Cannot register @llvm.assume call not in a basic block");
205 "Cannot register @llvm.assume call not in this function");
211 for (
auto &VH : AssumeHandles) {
216 "Cached assumption not inside this function!");
218 "Cached something other than a call to @llvm.assume!");
220 "Cache contains multiple copies of a call!");
239 OS <<
"Cached assumptions for function: " <<
F.getName() <<
"\n";
249 if (
I != ACT->AssumptionCaches.end())
250 ACT->AssumptionCaches.erase(
I);
259 auto I = AssumptionCaches.find_as(&
F);
260 if (
I != AssumptionCaches.end())
264 auto *
TTI = TTIWP ? &TTIWP->getTTI(
F) :
nullptr;
268 auto IP = AssumptionCaches.insert(std::make_pair(
269 FunctionCallbackVH(&
F,
this), std::make_unique<AssumptionCache>(
F,
TTI)));
270 assert(IP.second &&
"Scanning function already in the map?");
271 return *IP.first->second;
275 auto I = AssumptionCaches.find_as(&
F);
276 if (
I != AssumptionCaches.end())
277 return I->second.get();
290 for (
const auto &
I : AssumptionCaches) {
291 for (
auto &VH :
I.second->assumptions())
310 "Assumption Cache Tracker",
false,
true)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static void findAffectedValues(CallBase *CI, TargetTransformInfo *TTI, SmallVectorImpl< AssumptionCache::ResultElem > &Affected)
static cl::opt< bool > VerifyAssumptionCache("verify-assumption-cache", cl::Hidden, cl::desc("Enable verification of assumption cache"), cl::init(false))
static const Function * getParent(const Value *V)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This header defines various interfaces for pass management in LLVM.
uint64_t IntrinsicInst * II
FunctionAnalysisManager FAM
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
const SmallVectorImpl< MachineOperand > & Cond
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
This represents the llvm.assume intrinsic.
A function analysis which provides an AssumptionCache.
LLVM_ABI AssumptionCache run(Function &F, FunctionAnalysisManager &)
An immutable pass that tracks lazily created AssumptionCache objects.
~AssumptionCacheTracker() override
AssumptionCache * lookupAssumptionCache(Function &F)
Return the cached assumptions for a function if it has already been scanned.
void verifyAnalysis() const override
verifyAnalysis() - This member can be implemented by a analysis pass to check state of analysis infor...
AssumptionCache & getAssumptionCache(Function &F)
Get the cached assumptions for a function.
A cache of @llvm.assume calls within a function.
static void findValuesAffectedByOperandBundle(OperandBundleUse Bundle, function_ref< void(Value *)> InsertAffected)
Determine which values are affected by this assume operand bundle.
LLVM_ABI void registerAssumption(AssumeInst *CI)
Add an @llvm.assume intrinsic to this function's cache.
LLVM_ABI void updateAffectedValues(AssumeInst *CI)
Update the cache of values being affected by this assumption (i.e.
MutableArrayRef< WeakVH > assumptions()
Access the list of assumption handles currently tracked for this function.
LLVM_ABI void unregisterAssumption(AssumeInst *CI)
Remove an @llvm.assume intrinsic from this function's cache if it has been added to the cache earlier...
AssumptionCache(Function &F, TargetTransformInfo *TTI=nullptr)
Construct an AssumptionCache from a function by scanning all of its instructions.
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &AM)
LLVM Basic Block Representation.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
OperandBundleUse getOperandBundleAt(unsigned Index) const
Return the operand bundle at a specific index.
unsigned getNumOperandBundles() const
Return the number of operand bundles associated with this User.
virtual void deleted()
Callback for Value destruction.
AnalysisType * getAnalysisIfAvailable() const
getAnalysisIfAvailable<AnalysisType>() - Subclasses use this function to get analysis information tha...
A set of analyses that are preserved following a run of a transformation pass.
static PreservedAnalyses all()
Construct a special preserved set that preserves all passes.
size_type count(ConstPtrType Ptr) const
count - Return 1 if the specified pointer is in the set, 0 otherwise.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Analysis pass providing the TargetTransformInfo.
Value * getValPtr() const
LLVM Value Representation.
An efficient, type-erasing, non-owning reference to a callable.
const ParentTy * getParent() const
bool match(Val *V, const Pattern &P)
IntrinsicID_match m_Intrinsic()
Match intrinsic calls like this: m_Intrinsic<Intrinsic::fabs>(m_Value(X))
initializer< Ty > init(const Ty &Val)
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
constexpr StringRef IgnoreBundleTag
Tag in operand bundle indicating that this bundle should be ignored.
void erase(Container &C, ValueType V)
Wrapper function to remove a value from a container:
bool none_of(R &&Range, UnaryPredicate P)
Provide wrappers to std::none_of which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
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...
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI const Value * getUnderlyingObject(const Value *V, unsigned MaxLookup=MaxLookupSearchDepth)
This method strips off any GEP address adjustments, pointer casts or llvm.threadlocal....
LLVM_ABI void findValuesAffectedByCondition(Value *Cond, bool IsAssume, function_ref< void(Value *)> InsertAffected)
Call InsertAffected on all Values whose known bits / value may be affected by the condition Cond.
A special type used by analysis passes to provide an address that identifies that particular analysis...
unsigned Index
contains either ExprResultIdx or the index of the operand bundle containing the knowledge.
A lightweight accessor for an operand bundle meant to be passed around by value.
StringRef getTagName() const
Return the tag of this operand bundle as a string.