diff options
author | Chris Lattner <sabre@nondot.org> | 2011-01-03 18:28:15 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2011-01-03 18:28:15 +0000 |
commit | a12ba39a1d4d22c8c2d348f1397d52be58391177 (patch) | |
tree | 593460d83b9517952c7ace3802619d31cf83049b | |
parent | 18d49877530c04dd63578e6d9d0a1d3b6955502b (diff) |
fix PR8895: metadata operands don't have a strong use of their
nested values, so they can change and drop to null, which can
change the hash and cause havok.
It turns out that it isn't a good idea to value number stuff
with metadata operands anyway, so... don't.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122758 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Transforms/Scalar/EarlyCSE.cpp | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/lib/Transforms/Scalar/EarlyCSE.cpp b/lib/Transforms/Scalar/EarlyCSE.cpp index 9e7092bacd..61830e02d6 100644 --- a/lib/Transforms/Scalar/EarlyCSE.cpp +++ b/lib/Transforms/Scalar/EarlyCSE.cpp @@ -145,9 +145,15 @@ namespace { } static bool canHandle(Instruction *Inst) { - if (CallInst *CI = dyn_cast<CallInst>(Inst)) - return CI->onlyReadsMemory(); - return false; + CallInst *CI = dyn_cast<CallInst>(Inst); + if (CI == 0 || !CI->onlyReadsMemory()) + return false; + + // Check that there are no metadata operands. + for (unsigned i = 0, e = CI->getNumOperands(); i != e; ++i) + if (CI->getOperand(i)->getType()->isMetadataTy()) + return false; + return true; } }; } @@ -407,7 +413,7 @@ bool EarlyCSE::processNode(DomTreeNode *Node) { if (LastStore && LastStore->getPointerOperand() == SI->getPointerOperand()) { DEBUG(dbgs() << "EarlyCSE DEAD STORE: " << *LastStore << " due to: " - << *Inst << '\n'); + << *Inst << '\n'); LastStore->eraseFromParent(); Changed = true; ++NumDSE; |