From: Owen Anderson Date: Thu, 2 Aug 2007 17:56:05 +0000 (+0000) Subject: Fix a bug that was causing several miscompilations on SPEC. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=1c2763d3fe8b70d9b85cb84bbce311ee4b86c9e1;p=oota-llvm.git Fix a bug that was causing several miscompilations on SPEC. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40746 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/MemoryDependenceAnalysis.cpp b/lib/Analysis/MemoryDependenceAnalysis.cpp index a280fffb59b..47e47e5cba1 100644 --- a/lib/Analysis/MemoryDependenceAnalysis.cpp +++ b/lib/Analysis/MemoryDependenceAnalysis.cpp @@ -111,19 +111,31 @@ void MemoryDependenceAnalysis::nonLocalHelper(Instruction* query, while (!stack.empty()) { BasicBlock* BB = stack.back(); - visited.insert(BB); - - if (resp.count(BB)) { + if (visited.count(BB)) { stack.pop_back(); continue; } if (BB != block) { + visited.insert(BB); + Instruction* localDep = getDependency(query, 0, BB); if (localDep != NonLocal) { resp.insert(std::make_pair(BB, localDep)); + stack.pop_back(); + continue; } + } else if (BB == block && stack.size() > 1) { + visited.insert(BB); + + Instruction* localDep = getDependency(query, 0, BB); + if (localDep != query) + resp.insert(std::make_pair(BB, localDep)); + + stack.pop_back(); + + continue; } bool predOnStack = false; diff --git a/lib/Transforms/Scalar/GVN.cpp b/lib/Transforms/Scalar/GVN.cpp index e39e2eb16af..dfe0dff3ad6 100644 --- a/lib/Transforms/Scalar/GVN.cpp +++ b/lib/Transforms/Scalar/GVN.cpp @@ -658,7 +658,8 @@ namespace { SmallVector& toErase); bool processNonLocalLoad(LoadInst* L, SmallVector& toErase); Value *GetValueForBlock(BasicBlock *BB, LoadInst* orig, - DenseMap &Phis); + DenseMap &Phis, + bool top_level = false); void dump(DenseMap& d); }; @@ -715,11 +716,12 @@ void GVN::dump(DenseMap& d) { /// GetValueForBlock - Get the value to use within the specified basic block. /// available values are in Phis. Value *GVN::GetValueForBlock(BasicBlock *BB, LoadInst* orig, - DenseMap &Phis) { + DenseMap &Phis, + bool top_level) { // If we have already computed this value, return the previously computed val. Value *&V = Phis[BB]; - if (V) return V; + if (V && ! top_level) return V; BasicBlock* singlePred = BB->getSinglePredecessor(); if (singlePred) @@ -799,7 +801,7 @@ bool GVN::processNonLocalLoad(LoadInst* L, SmallVector& toErase } SmallPtrSet visited; - Value* v = GetValueForBlock(L->getParent(), L, repl); + Value* v = GetValueForBlock(L->getParent(), L, repl, true); MD.removeInstruction(L); L->replaceAllUsesWith(v);