Enable Load PRE. This teaches GVN to push partially redundant loads up the
authorChris Lattner <sabre@nondot.org>
Mon, 15 Dec 2008 05:28:29 +0000 (05:28 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 15 Dec 2008 05:28:29 +0000 (05:28 +0000)
CFG when there is exactly one predecessor where the load is not available.
This is designed to not increase code size but still eliminate partially
redundant loads.  This fires 1765 times on 403.gcc even though it doesn't
do critical edge splitting yet (the most common reason for it to fail).

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

lib/Transforms/Scalar/GVN.cpp

index 3662424923822132b5ac40efb81630e3b27bf146..75584decf040116da1d4f8d1ad8f47c790329f4a 100644 (file)
@@ -48,7 +48,7 @@ STATISTIC(NumPRELoad, "Number of loads PRE'd");
 
 static cl::opt<bool> EnablePRE("enable-pre",
                                cl::init(true), cl::Hidden);
-cl::opt<bool> EnableLoadPRE("enable-load-pre"/*, cl::init(true)*/);
+cl::opt<bool> EnableLoadPRE("enable-load-pre", cl::init(true));
 
 //===----------------------------------------------------------------------===//
 //                         ValueTable Class
@@ -957,6 +957,11 @@ bool GVN::processNonLocalLoad(LoadInst *LI,
   if (Deps.size() > 100)
     return false;
   
+  // If we had a phi translation failure, we'll have a single entry which is a
+  // clobber in the current block.  Reject this early.
+  if (Deps.size() == 1 && Deps[0].second.isClobber())
+    return false;
+  
   // Filter out useless results (non-locals, etc).  Keep track of the blocks
   // where we have a value available in repl, also keep track of whether we see
   // dependencies that produce an unknown value for the load (such as a call