diff options
author | Sanjay Patel <spatel@rotateright.com> | 2016-12-31 17:37:01 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2016-12-31 17:37:01 +0000 |
commit | 7fd779f09f00b04fbd59c15ce28614cdeea1e0b4 (patch) | |
tree | 3e26487867ab1e7ef7bba2e11b3a727dedadbe81 | |
parent | 21711c451e83efa8d83d3d202525ea3b2b2ca4c8 (diff) | |
download | bcm5719-llvm-7fd779f09f00b04fbd59c15ce28614cdeea1e0b4.tar.gz bcm5719-llvm-7fd779f09f00b04fbd59c15ce28614cdeea1e0b4.zip |
[ValueTracking] make dominator tree requirement explicit for isKnownNonNullFromDominatingCondition(); NFCI
I don't think this hole is currently exposed, but I crashed regression tests for
jump-threading and loop-vectorize after I added calls to isKnownNonNullAt() in
InstSimplify as part of trying to solve PR28430:
https://llvm.org/bugs/show_bug.cgi?id=28430
That's because they call into value tracking with a context instruction, but no
other parts of the query structure filled in.
For more background, see the discussion in:
https://reviews.llvm.org/D27855
llvm-svn: 290786
-rw-r--r-- | llvm/include/llvm/Analysis/ValueTracking.h | 8 | ||||
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 7 |
2 files changed, 10 insertions, 5 deletions
diff --git a/llvm/include/llvm/Analysis/ValueTracking.h b/llvm/include/llvm/Analysis/ValueTracking.h index 5a3e6346ad8..dd767217345 100644 --- a/llvm/include/llvm/Analysis/ValueTracking.h +++ b/llvm/include/llvm/Analysis/ValueTracking.h @@ -308,12 +308,12 @@ template <typename T> class ArrayRef; bool isKnownNonNull(const Value *V); /// Return true if this pointer couldn't possibly be null. If the context - /// instruction is specified, perform context-sensitive analysis and return - /// true if the pointer couldn't possibly be null at the specified - /// instruction. + /// instruction and dominator tree are specified, perform context-sensitive + /// analysis and return true if the pointer couldn't possibly be null at the + /// specified instruction. bool isKnownNonNullAt(const Value *V, const Instruction *CtxI = nullptr, - const DominatorTree *DT = nullptr); + const DominatorTree *DT = nullptr); /// Return true if it is valid to use the assumptions provided by an /// assume intrinsic, I, at the point in the control-flow identified by the diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index 30bd08471d5..48f5c59ba61 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -3368,6 +3368,8 @@ static bool isKnownNonNullFromDominatingCondition(const Value *V, const DominatorTree *DT) { assert(V->getType()->isPointerTy() && "V must be pointer type"); assert(!isa<ConstantData>(V) && "Did not expect ConstantPointerNull"); + assert(CtxI && "Context instruction required for analysis"); + assert(DT && "Dominator tree required for analysis"); unsigned NumUsesExplored = 0; for (auto *U : V->users()) { @@ -3410,7 +3412,10 @@ bool llvm::isKnownNonNullAt(const Value *V, const Instruction *CtxI, if (isKnownNonNull(V)) return true; - return CtxI ? ::isKnownNonNullFromDominatingCondition(V, CtxI, DT) : false; + if (!CtxI || !DT) + return false; + + return ::isKnownNonNullFromDominatingCondition(V, CtxI, DT); } OverflowResult llvm::computeOverflowForUnsignedMul(const Value *LHS, |