From 16db1f70b780db099972b05ec6418a3f82d46d91 Mon Sep 17 00:00:00 2001 From: Owen Anderson Date: Tue, 13 May 2008 13:41:23 +0000 Subject: [PATCH] Make the non-local CSE safety checks slightly more thorough. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51035 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Transforms/Scalar/GVN.cpp | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/lib/Transforms/Scalar/GVN.cpp b/lib/Transforms/Scalar/GVN.cpp index ba7f8b37d83..3333ecdc798 100644 --- a/lib/Transforms/Scalar/GVN.cpp +++ b/lib/Transforms/Scalar/GVN.cpp @@ -443,7 +443,7 @@ uint32_t ValueTable::lookup_or_add(Value* V) { DenseMap deps; MD->getNonLocalDependency(C, deps); - Value* dep = 0; + CallInst* cdep = 0; for (DenseMap::iterator I = deps.begin(), E = deps.end(); I != E; ++I) { @@ -453,22 +453,24 @@ uint32_t ValueTable::lookup_or_add(Value* V) { return nextValueNumber++; } else if (I->second != MemoryDependenceAnalysis::NonLocal) { if (DT->dominates(I->first, C->getParent())) { - dep = I->second; + if (CallInst* CD = dyn_cast(I->second)) + cdep = CD; + else { + valueNumbering.insert(std::make_pair(V, nextValueNumber)); + return nextValueNumber++; + } } else { valueNumbering.insert(std::make_pair(V, nextValueNumber)); - return nextValueNumber++; } } } - if (!dep || !isa(dep)) { + if (!cdep) { valueNumbering.insert(std::make_pair(V, nextValueNumber)); return nextValueNumber++; } - CallInst* cdep = cast(dep); - if (cdep->getCalledFunction() != C->getCalledFunction() || cdep->getNumOperands() != C->getNumOperands()) { valueNumbering.insert(std::make_pair(V, nextValueNumber));