Fix PR46845: handle scop parameters before scev analysis.
authorSebastian Pop <sebastian.pop@amd.com>
Wed, 15 Dec 2010 05:04:50 +0000 (05:04 +0000)
committerSebastian Pop <spop@gcc.gnu.org>
Wed, 15 Dec 2010 05:04:50 +0000 (05:04 +0000)
2010-12-14  Sebastian Pop  <sebastian.pop@amd.com>

PR tree-optimization/46845
* sese.c (scalar_evolution_in_region): Handle scop parameters
before scev analysis.

* gcc.dg/graphite/id-pr46845.c: New.

From-SVN: r167844

gcc/ChangeLog
gcc/sese.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/graphite/id-pr46845.c [new file with mode: 0644]

index 66c11c4..549b290 100644 (file)
@@ -1,5 +1,11 @@
 2010-12-14  Sebastian Pop  <sebastian.pop@amd.com>
 
+       PR tree-optimization/46845
+       * sese.c (scalar_evolution_in_region): Handle scop parameters
+       before scev analysis.
+
+2010-12-14  Sebastian Pop  <sebastian.pop@amd.com>
+
        PR tree-optimization/46928
        * tree-data-ref.c (analyze_overlapping_iterations): Handle "A[p] == A[p]"
        in data dependence analysis with p a parameter of the loop.
index 3bf6bea..076f07a 100644 (file)
@@ -801,14 +801,16 @@ scalar_evolution_in_region (sese region, loop_p loop, tree t)
   struct loop *def_loop;
   basic_block before = block_before_sese (region);
 
+  /* SCOP parameters.  */
+  if (TREE_CODE (t) == SSA_NAME
+      && !defined_in_sese_p (t, region))
+    return t;
+
   if (TREE_CODE (t) != SSA_NAME
       || loop_in_sese_p (loop, region))
     return instantiate_scev (before, loop,
                             analyze_scalar_evolution (loop, t));
 
-  if (!defined_in_sese_p (t, region))
-    return t;
-
   def = SSA_NAME_DEF_STMT (t);
   def_loop = loop_containing_stmt (def);
 
index fae339b..ce47905 100644 (file)
@@ -1,5 +1,10 @@
 2010-12-14  Sebastian Pop  <sebastian.pop@amd.com>
 
+       PR tree-optimization/46845
+       * gcc.dg/graphite/id-pr46845.c: New.
+
+2010-12-14  Sebastian Pop  <sebastian.pop@amd.com>
+
        PR tree-optimization/46928
        * gcc.dg/tree-ssa/ldist-17.c: New.
 
diff --git a/gcc/testsuite/gcc.dg/graphite/id-pr46845.c b/gcc/testsuite/gcc.dg/graphite/id-pr46845.c
new file mode 100644 (file)
index 0000000..f4da78e
--- /dev/null
@@ -0,0 +1,17 @@
+/* { dg-options "-O2 -ffast-math -fgraphite-identity -w -Wno-psabi" { target { i?86-*-* x86_64-*-* } } } */
+
+typedef float V2SF __attribute__ ((vector_size (128)));
+
+V2SF
+foo (int x, V2SF a)
+{
+  V2SF b;
+  if (x & 42)
+    b = a;
+  else
+    b = a + (V2SF) {1.0f/0.0f - 1.0f/0.0f, 1.0f/0.0f - 1.0f/0.0f};
+  while (x--)
+    a += b;
+
+  return a;
+}