aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@gcc.gnu.org>2008-12-05 15:33:14 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2008-12-05 15:33:14 +0100
commit6fc4fb069d3d11880c98cd3de62e6aa1ed26ca87 (patch)
tree65f96fe8f394f97f8b06726c8feb3b56a27cbcb2 /gcc
parent37fe763dee6c9ea60831ac1bbfe98313899d5ffe (diff)
downloadgcc-6fc4fb069d3d11880c98cd3de62e6aa1ed26ca87.zip
gcc-6fc4fb069d3d11880c98cd3de62e6aa1ed26ca87.tar.gz
gcc-6fc4fb069d3d11880c98cd3de62e6aa1ed26ca87.tar.bz2
re PR tree-optimization/37716 (ice for legal C++ code with -O2 on 20080926)
PR tree-optimization/37716 * gimplify.c (gimplify_expr): Allow COND_EXPR if gimplify_ctxp->allow_rhs_cond_expr. From-SVN: r142476
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog8
-rw-r--r--gcc/gimplify.c2
2 files changed, 8 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 22ffd3a..60d4455 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,4 +1,10 @@
-2008-12-05 Uros Bizjak <ubizjak@gmail.com>
+2008-12-05 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/37716
+ * gimplify.c (gimplify_expr): Allow COND_EXPR if
+ gimplify_ctxp->allow_rhs_cond_expr.
+
+2008-12-05 Uros Bizjak <ubizjak@gmail.com>
* config/alpha/alpha.c (alpha_fold_vector_minmax): Create
VIEW_CONVERT_EXPR to convert output to long_integer_type_node.
diff --git a/gcc/gimplify.c b/gcc/gimplify.c
index 09f130e..2fea882 100644
--- a/gcc/gimplify.c
+++ b/gcc/gimplify.c
@@ -6941,7 +6941,7 @@ gimplify_expr (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p,
&& code != ASM_EXPR
&& code != BIND_EXPR
&& code != CATCH_EXPR
- && code != COND_EXPR
+ && (code != COND_EXPR || gimplify_ctxp->allow_rhs_cond_expr)
&& code != EH_FILTER_EXPR
&& code != GOTO_EXPR
&& code != LABEL_EXPR