summaryrefslogtreecommitdiff
path: root/gcc/tree-chrec.h
diff options
context:
space:
mode:
authorSebastian Pop <sebpop@gmail.com>2007-06-19 18:35:39 +0000
committerSebastian Pop <spop@gcc.gnu.org>2007-06-19 18:35:39 +0000
commit0f7c07751c7b29ab1e795bc26ff2b5159a945163 (patch)
tree59590f3ac54b838633a0d96f69aa69f1d2b3fe2b /gcc/tree-chrec.h
parente70312d4996ba059653d899eabf16fc6b551fbbc (diff)
downloadgcc-0f7c07751c7b29ab1e795bc26ff2b5159a945163.tar.gz
re PR tree-optimization/32367 (internal compiler error: in build_polynomial_chrec, at tree-chrec.h:113)
PR tree-optimization/32367 * tree-chrec.h (build_polynomial_chrec): Verify that the left hand side of the chrec has no evolution in that loop. * testsuite/gcc.dg/tree-ssa/pr32367.c: New. From-SVN: r125855
Diffstat (limited to 'gcc/tree-chrec.h')
-rw-r--r--gcc/tree-chrec.h43
1 files changed, 24 insertions, 19 deletions
diff --git a/gcc/tree-chrec.h b/gcc/tree-chrec.h
index e6bea92eb3b..5e9038ce4e6 100644
--- a/gcc/tree-chrec.h
+++ b/gcc/tree-chrec.h
@@ -83,6 +83,7 @@ extern bool tree_contains_chrecs (tree, int *);
extern bool evolution_function_is_affine_multivariate_p (tree, int);
extern bool evolution_function_is_univariate_p (tree);
extern unsigned nb_vars_in_chrec (tree);
+extern bool evolution_function_is_invariant_p (tree, int);
/* Determines whether CHREC is equal to zero. */
@@ -98,6 +99,24 @@ chrec_zerop (tree chrec)
return false;
}
+/* Determines whether CHREC is a loop invariant with respect to LOOP_NUM.
+ Set the result in RES and return true when the property can be computed. */
+
+static inline bool
+no_evolution_in_loop_p (tree chrec, unsigned loop_num, bool *res)
+{
+ tree scev;
+
+ if (chrec == chrec_not_analyzed_yet
+ || chrec == chrec_dont_know
+ || chrec_contains_symbols_defined_in_loop (chrec, loop_num))
+ return false;
+
+ scev = hide_evolution_in_other_loops_than_loop (chrec, loop_num);
+ *res = !tree_is_chrec (scev);
+ return true;
+}
+
/* Build a polynomial chain of recurrence. */
static inline tree
@@ -105,10 +124,15 @@ build_polynomial_chrec (unsigned loop_num,
tree left,
tree right)
{
+ bool val;
+
if (left == chrec_dont_know
|| right == chrec_dont_know)
return chrec_dont_know;
+ if (no_evolution_in_loop_p (left, loop_num, &val) && !val)
+ return chrec_dont_know;
+
if (POINTER_TYPE_P (TREE_TYPE (left)))
gcc_assert (sizetype == TREE_TYPE (right));
else
@@ -140,7 +164,6 @@ evolution_function_is_constant_p (tree chrec)
}
}
-extern bool evolution_function_is_invariant_p (tree, int);
/* Determine whether the given tree is an affine evolution function or not. */
static inline bool
@@ -183,24 +206,6 @@ tree_does_not_contain_chrecs (tree expr)
return !tree_contains_chrecs (expr, NULL);
}
-/* Determines whether CHREC is a loop invariant with respect to LOOP_NUM.
- Set the result in RES and return true when the property can be computed. */
-
-static inline bool
-no_evolution_in_loop_p (tree chrec, unsigned loop_num, bool *res)
-{
- tree scev;
-
- if (chrec == chrec_not_analyzed_yet
- || chrec == chrec_dont_know
- || chrec_contains_symbols_defined_in_loop (chrec, loop_num))
- return false;
-
- scev = hide_evolution_in_other_loops_than_loop (chrec, loop_num);
- *res = !tree_is_chrec (scev);
- return true;
-}
-
/* Returns the type of the chrec. */
static inline tree