fold-const.c (fold): Fold (A & ~B) - (A & B) into (A ^ B) - B for any B.
authorKazu Hirata <kazu@cs.umass.edu>
Tue, 30 Sep 2003 21:07:41 +0000 (21:07 +0000)
committerKazu Hirata <kazu@gcc.gnu.org>
Tue, 30 Sep 2003 21:07:41 +0000 (21:07 +0000)
* fold-const.c (fold): Fold (A & ~B) - (A & B) into
(A ^ B) - B for any B.

From-SVN: r71953

gcc/ChangeLog
gcc/fold-const.c

index b14dd7e33d38dee580d07b00832a79f1cdfde3e4..9ccd1a068eb31255c9cde898ddcb74ac4915e8ba 100644 (file)
@@ -1,3 +1,8 @@
+2003-09-30  Kazu Hirata  <kazu@cs.umass.edu>
+
+       * fold-const.c (fold): Fold (A & ~B) - (A & B) into
+       (A ^ B) - B for any B.
+
 2003-09-30  Nathanael Nerode  <neroden@gcc.gnu.org>
 
        * config.gcc (arm*-*-kaos*, i[34567]86-*-kaos*, powerpc-*-kaos*,
index 54458ef95ae1d911fc20771ffa5c1f73f845cf6c..f5a6f78a14f618a76d9fe75f6be95ed2c97a6d9a 100644 (file)
@@ -6023,17 +6023,13 @@ fold (tree expr)
          if (TREE_CODE (arg0) == BIT_AND_EXPR
              && TREE_CODE (arg1) == BIT_AND_EXPR
              && operand_equal_p (TREE_OPERAND (arg0, 0),
-                                 TREE_OPERAND (arg1, 0), 0)
-             && TREE_CODE (TREE_OPERAND (arg0, 1)) == INTEGER_CST
-             && TREE_CODE (TREE_OPERAND (arg1, 1)) == INTEGER_CST)
+                                 TREE_OPERAND (arg1, 0), 0))
            {
              tree mask0 = TREE_OPERAND (arg0, 1);
              tree mask1 = TREE_OPERAND (arg1, 1);
              tree tem = fold (build1 (BIT_NOT_EXPR, type, mask0));
              
-             if (operand_equal_p (tem, mask1, 0)
-                 && integer_pow2p (fold (build (PLUS_EXPR, type,
-                                                mask1, integer_one_node))))
+             if (operand_equal_p (tem, mask1, 0))
                {
                  tem = fold (build (BIT_XOR_EXPR, type,
                                     TREE_OPERAND (arg0, 0), mask1));