reapply r90093 with an addition of keeping the forward
authorChris Lattner <sabre@nondot.org>
Mon, 30 Nov 2009 02:26:29 +0000 (02:26 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 30 Nov 2009 02:26:29 +0000 (02:26 +0000)
and reverse nonlocal memdep maps in synch, this should
fix 255.vortex.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@90107 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/MemoryDependenceAnalysis.cpp

index b5069ecbc9267f3dad70f2d5facc8825178b172f..21baf427ea456f1c073f62d2fe6e63b1d05051d1 100644 (file)
@@ -1156,8 +1156,21 @@ getNonLocalPointerDepFromBB(Value *Pointer, uint64_t PointeeSize,
       // that predecessor.  We can still do PRE of the load, which would insert
       // a computation of the pointer in this predecessor.
       if (PredPtr == 0) {
-        Result.push_back(NonLocalDepEntry(Pred,
-                              MemDepResult::getClobber(Pred->getTerminator())));
+        // Add the entry to the Result list.
+        NonLocalDepEntry Entry(Pred,
+                               MemDepResult::getClobber(Pred->getTerminator()));
+        Result.push_back(Entry);
+
+        // Add it to the cache for this CacheKey so that subsequent queries get
+        // this result.
+        Cache = &NonLocalPointerDeps[CacheKey].second;
+        MemoryDependenceAnalysis::NonLocalDepInfo::iterator It =
+          std::upper_bound(Cache->begin(), Cache->end(), Entry);
+        Cache->insert(It, Entry);
+        Cache = 0;
+        
+        // Add it to the reverse map next.
+        ReverseNonLocalPtrDeps[Pred->getTerminator()].insert(CacheKey);
         continue;
       }