From 8df67f4fe595411dfc28a71118fc8c74e65e700e Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Tue, 21 Oct 2008 00:57:27 +0200 Subject: [PATCH] gimplify.c (gimplify_expr): Drop TREE_OVERFLOW from INTEGER_CSTs. * gimplify.c (gimplify_expr): Drop TREE_OVERFLOW from INTEGER_CSTs. From-SVN: r141251 --- gcc/ChangeLog | 5 +++++ gcc/gimplify.c | 10 ++++++++++ 2 files changed, 15 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ce553c6bf83..c55ccfaae0b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2008-10-21 Jakub Jelinek + + * gimplify.c (gimplify_expr): Drop TREE_OVERFLOW from + INTEGER_CSTs. + 2008-10-20 Daniel Berlin * tree-ssa-pre.c (insert_into_preds_of_block): Don't rewrite constant diff --git a/gcc/gimplify.c b/gcc/gimplify.c index c6a79fbe8b7..d2625a7f715 100644 --- a/gcc/gimplify.c +++ b/gcc/gimplify.c @@ -6441,6 +6441,16 @@ gimplify_expr (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p, /* Constants need not be gimplified. */ case INTEGER_CST: + /* Don't preserve TREE_OVERFLOW flags, it only inhibits + many optimizations and FEs should have taken care of + reporting all the required diagnostics. */ + if (TREE_OVERFLOW (*expr_p)) + *expr_p = build_int_cst_wide (TREE_TYPE (*expr_p), + TREE_INT_CST_LOW (*expr_p), + TREE_INT_CST_HIGH (*expr_p)); + ret = GS_ALL_DONE; + break; + case REAL_CST: case FIXED_CST: case STRING_CST: