From: jakub Date: Thu, 14 Oct 2010 19:34:16 +0000 (+0000) Subject: PR tree-optimization/46008 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=bc2d6e846ba5988aa6a0527cfe5c55d4afa822a0;p=thirdparty%2Fgcc.git PR tree-optimization/46008 * tree-if-conv.c (predicate_bbs): Try to canonicalize c2 if possible. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@165476 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index bab695847173..499efa5ca60c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-10-14 Jakub Jelinek + + PR tree-optimization/46008 + * tree-if-conv.c (predicate_bbs): Try to canonicalize c2 + if possible. + 2010-10-14 Richard Guenther PR tree-optimization/44913 diff --git a/gcc/tree-if-conv.c b/gcc/tree-if-conv.c index e92090f9085b..642dbda24cb6 100644 --- a/gcc/tree-if-conv.c +++ b/gcc/tree-if-conv.c @@ -915,7 +915,7 @@ predicate_bbs (loop_p loop) case GIMPLE_COND: { - tree c2; + tree c2, tem; edge true_edge, false_edge; location_t loc = gimple_location (stmt); tree c = fold_build2_loc (loc, gimple_cond_code (stmt), @@ -932,6 +932,9 @@ predicate_bbs (loop_p loop) /* If C is false, then FALSE_EDGE is taken. */ c2 = invert_truthvalue_loc (loc, unshare_expr (c)); + tem = canonicalize_cond_expr_cond (c2); + if (tem) + c2 = tem; add_to_dst_predicate_list (loop, false_edge, cond, c2); cond = NULL_TREE;