Changes in directory llvm/lib/Transforms/Scalar:

LoopUnswitch.cpp updated: 1.43 -> 1.44
---
Log message:

Switch to a very conservative heuristic for determining when loop-unswitching
will be profitable.  This is mainly to remove some cases where excessive
unswitching would result in long compile times and/or huge generated code.

Once someone comes up with a better heuristic that avoids these cases, this
should be switched out.


---
Diffs of the changes:  (+5 -5)

 LoopUnswitch.cpp |   10 +++++-----
 1 files changed, 5 insertions(+), 5 deletions(-)


Index: llvm/lib/Transforms/Scalar/LoopUnswitch.cpp
diff -u llvm/lib/Transforms/Scalar/LoopUnswitch.cpp:1.43 
llvm/lib/Transforms/Scalar/LoopUnswitch.cpp:1.44
--- llvm/lib/Transforms/Scalar/LoopUnswitch.cpp:1.43    Wed Jun 28 11:38:55 2006
+++ llvm/lib/Transforms/Scalar/LoopUnswitch.cpp Wed Jun 28 12:47:50 2006
@@ -333,11 +333,11 @@
   if (IsTrivialUnswitchCondition(L, LIC))
     return 0;
   
-  // If the loop is really large (over twice our threshold) don't even consider
-  // unswitching it.  This will produce a really large loop with lots of empty
-  // blocks.
-  if (L->getBlocks().size() > 2*Threshold)
-    return 2*Threshold;
+  // FIXME: This is really overly conservative.  However, more liberal 
+  // estimations have thus far resulted in excessive unswitching, which is bad
+  // both in compile time and in code size.  This should be replaced once
+  // someone figures out how a good estimation.
+  return L->getBlocks().size();
   
   unsigned Cost = 0;
   // FIXME: this is brain dead.  It should take into consideration code



_______________________________________________
llvm-commits mailing list
llvm-commits@cs.uiuc.edu
http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits

Reply via email to