From 52b27f98cf3b03e9b6b876539b00aaf8ce279a44 Mon Sep 17 00:00:00 2001 From: Andrew Pinski Date: Fri, 8 Jul 2005 19:26:16 +0000 Subject: [PATCH] re PR tree-optimization/22329 (VRP produces mis-matched (non compatible) types in MODIFY_EXPR) 2005-07-08 Andrew Pinski PR tree-opt/22329 * gcc.dg/pr22329.c: New test. 2005-07-08 Andrew Pinski PR tree-opt/22329 * tree-ssa-propagate.c (fold_predicate_in): Convert the value to the correct type if we have a MODIFY_EXPR. From-SVN: r101789 --- gcc/ChangeLog | 6 ++++++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gcc.dg/pr22329.c | 9 +++++++++ gcc/tree-ssa-propagate.c | 9 ++++++++- 4 files changed, 28 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gcc.dg/pr22329.c diff --git a/gcc/ChangeLog b/gcc/ChangeLog index adceec9b310..2c169d2cc93 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2005-07-08 Andrew Pinski + + PR tree-opt/22329 + * tree-ssa-propagate.c (fold_predicate_in): Convert the value + to the correct type if we have a MODIFY_EXPR. + 2005-07-08 Kazu Hirata PR tree-optimization/22360 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 862e457baff..f61b47363cd 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-07-08 Andrew Pinski + + PR tree-opt/22329 + * gcc.dg/pr22329.c: New test. + 2005-07-08 Kazu Hirata PR tree-optimization/20139 diff --git a/gcc/testsuite/gcc.dg/pr22329.c b/gcc/testsuite/gcc.dg/pr22329.c new file mode 100644 index 00000000000..94e32d69593 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr22329.c @@ -0,0 +1,9 @@ +/* { dg-do compile } */ +/* { dg-options "-O2" } */ +int f(int i) +{ + int k = 0; + if (i == 0) + k = i == 0; + return k; +} diff --git a/gcc/tree-ssa-propagate.c b/gcc/tree-ssa-propagate.c index b9b308e6078..07b13e3fa5f 100644 --- a/gcc/tree-ssa-propagate.c +++ b/gcc/tree-ssa-propagate.c @@ -1018,11 +1018,15 @@ static bool fold_predicate_in (tree stmt) { tree *pred_p = NULL; + bool modify_expr_p = false; tree val; if (TREE_CODE (stmt) == MODIFY_EXPR && COMPARISON_CLASS_P (TREE_OPERAND (stmt, 1))) - pred_p = &TREE_OPERAND (stmt, 1); + { + modify_expr_p = true; + pred_p = &TREE_OPERAND (stmt, 1); + } else if (TREE_CODE (stmt) == COND_EXPR) pred_p = &COND_EXPR_COND (stmt); else @@ -1031,6 +1035,9 @@ fold_predicate_in (tree stmt) val = vrp_evaluate_conditional (*pred_p, true); if (val) { + if (modify_expr_p) + val = fold_convert (TREE_TYPE (*pred_p), val); + if (dump_file) { fprintf (dump_file, "Folding predicate "); -- 2.30.2