OSDN Git Service

* gcc.dg/tree-prof/unroll-1.c: New testcase.
authorhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 20 Oct 2012 15:51:16 +0000 (15:51 +0000)
committerhubicka <hubicka@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 20 Oct 2012 15:51:16 +0000 (15:51 +0000)
* loop-unroll.c (decide_unroll_constant_iterations): Don't
perform unrolling for loops with low iterations bounds or estimates.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@192638 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/loop-unroll.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/tree-prof/unroll-1.c [new file with mode: 0644]

index 47263fd..0403a90 100644 (file)
@@ -1,5 +1,10 @@
 2012-10-20  Jan Hubicka  <jh@suse.cz>
 
+       * loop-unroll.c (decide_unroll_constant_iterations): Don't
+       perform unrolling for loops with low iterations bounds or estimates.
+
+2012-10-20  Jan Hubicka  <jh@suse.cz>
+
        * loop-iv.c (iv_number_of_iterations): Record the upper bound
        only if there are no further conditions on it.
 
index 0dd8b0a..2398e6d 100644 (file)
@@ -519,6 +519,7 @@ decide_unroll_constant_iterations (struct loop *loop, int flags)
 {
   unsigned nunroll, nunroll_by_av, best_copies, best_unroll = 0, n_copies, i;
   struct niter_desc *desc;
+  double_int iterations;
 
   if (!(flags & UAP_UNROLL))
     {
@@ -561,8 +562,14 @@ decide_unroll_constant_iterations (struct loop *loop, int flags)
       return;
     }
 
-  /* Check whether the loop rolls enough to consider.  */
-  if (desc->niter < 2 * nunroll)
+  /* Check whether the loop rolls enough to consider.  
+     Consult also loop bounds and profile; in the case the loop has more
+     than one exit it may well loop less than determined maximal number
+     of iterations.  */
+  if (desc->niter < 2 * nunroll
+      || ((estimated_loop_iterations (loop, &iterations)
+          || max_loop_iterations (loop, &iterations))
+         && iterations.ult (double_int::from_shwi (2 * nunroll))))
     {
       if (dump_file)
        fprintf (dump_file, ";; Not unrolling loop, doesn't roll\n");
index adb5542..a10971c 100644 (file)
@@ -1,3 +1,7 @@
+2012-10-20  Jan Hubicka  <jh@suse.cz>
+
+       * gcc.dg/tree-prof/unroll-1.c: New testcase.
+
 2012-10-19  Janus Weil  <janus@gcc.gnu.org>
 
        PR fortran/54224
diff --git a/gcc/testsuite/gcc.dg/tree-prof/unroll-1.c b/gcc/testsuite/gcc.dg/tree-prof/unroll-1.c
new file mode 100644 (file)
index 0000000..b1c6b8b
--- /dev/null
@@ -0,0 +1,24 @@
+/* { dg-options "-O3 -fdump-rtl-loop2_unroll -funroll-loops -fno-peel-loops" } */
+void abort ();
+
+int a[1000];
+int
+__attribute__ ((noinline))
+t()
+{
+  int i;
+  for (i=0;i<1000;i++)
+    if (!a[i])
+      return 1;
+  abort ();
+}
+main()
+{
+  int i;
+  for (i=0;i<1000;i++)
+    t();
+  return 0;
+}
+/* { dg-final-use { scan-rtl-dump "Considering unrolling loop with constant number of iterations" "loop2_unroll" } } */
+/* { dg-final-use { cleanup-rtl-dump "Not unrolling loop, doesn't roll" } } */
+/* { dg-options "-O3 -fdump-rtl-loop2_unroll -funroll-loops -fno-peel-loops" } */