From: Roger Sayle Date: Tue, 23 Mar 2004 19:11:35 +0000 (+0000) Subject: fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when A is nonnegative... X-Git-Tag: releases/gcc-4.0.0~9201 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b1500d001aa58e8712c201ce9fbbad9288a87649;p=thirdparty%2Fgcc.git fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when A is nonnegative or B is nonnegative. * fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when A is nonnegative or B is nonnegative. Similarly A|B is nonnegative when both A and B are nonnegative. (tree_expr_nonzero_p): A|B is nonzero when A is nonzero or B is nonzero. From-SVN: r79870 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index af4fae53571c..603f6a45f29c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2004-03-23 Roger Sayle + + * fold-const.c (tree_expr_nonnegative_p): A&B is nonnegative when + A is nonnegative or B is nonnegative. Similarly A|B is nonnegative + when both A and B are nonnegative. + (tree_expr_nonzero_p): A|B is nonzero when A is nonzero or B is + nonzero. + 2004-03-23 Kazu Hirata * fold-const.c (fold): Remove cases for INTEGER_CST, REAL_CST, diff --git a/gcc/fold-const.c b/gcc/fold-const.c index 948a46c939da..417d1a45c8ea 100644 --- a/gcc/fold-const.c +++ b/gcc/fold-const.c @@ -8717,6 +8717,13 @@ tree_expr_nonnegative_p (tree t) return tree_expr_nonnegative_p (TREE_OPERAND (t, 0)) && tree_expr_nonnegative_p (TREE_OPERAND (t, 1)); + case BIT_AND_EXPR: + return tree_expr_nonnegative_p (TREE_OPERAND (t, 1)) + || tree_expr_nonnegative_p (TREE_OPERAND (t, 0)); + case BIT_IOR_EXPR: + return tree_expr_nonnegative_p (TREE_OPERAND (t, 0)) + && tree_expr_nonnegative_p (TREE_OPERAND (t, 1)); + case NOP_EXPR: { tree inner_type = TREE_TYPE (TREE_OPERAND (t, 0)); @@ -8955,6 +8962,10 @@ tree_expr_nonzero_p (tree t) case NON_LVALUE_EXPR: return tree_expr_nonzero_p (TREE_OPERAND (t, 0)); + case BIT_IOR_EXPR: + return tree_expr_nonzero_p (TREE_OPERAND (t, 1)) + || tree_expr_nonzero_p (TREE_OPERAND (t, 0)); + default: break; }