aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKazu Hirata <kazu@cs.umass.edu>2003-02-14 17:50:30 +0000
committerKazu Hirata <kazu@gcc.gnu.org>2003-02-14 17:50:30 +0000
commit6017c7192b72a44f762521140f270ae91060c2f8 (patch)
treea68ee3f29bb4d7d981224b90d9c08e4f68d48a8a
parentb8c86c6d07a8c404a696d908b0734af9493c0884 (diff)
downloadgcc-6017c7192b72a44f762521140f270ae91060c2f8.zip
gcc-6017c7192b72a44f762521140f270ae91060c2f8.tar.gz
gcc-6017c7192b72a44f762521140f270ae91060c2f8.tar.bz2
simplify-rtx.c (simplify_binary_operation): Simplify ~y when (x - (x & y)) is found.
* simplify-rtx.c (simplify_binary_operation): Simplify ~y when (x - (x & y)) is found. From-SVN: r62906
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/simplify-rtx.c14
2 files changed, 15 insertions, 4 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 0958064..a51c6bd 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2003-02-14 Kazu Hirata <kazu@cs.umass.edu>
+
+ * simplify-rtx.c (simplify_binary_operation): Simplify ~y when
+ (x - (x & y)) is found.
+
2003-02-14 Rainer Orth <ro@TechFak.Uni-Bielefeld.DE>
* configure.in: Fix typo.
diff --git a/gcc/simplify-rtx.c b/gcc/simplify-rtx.c
index e874c2a..9d3b213 100644
--- a/gcc/simplify-rtx.c
+++ b/gcc/simplify-rtx.c
@@ -1338,11 +1338,17 @@ simplify_binary_operation (code, mode, op0, op1)
if (GET_CODE (op1) == AND)
{
if (rtx_equal_p (op0, XEXP (op1, 0)))
- return simplify_gen_binary (AND, mode, op0,
- gen_rtx_NOT (mode, XEXP (op1, 1)));
+ {
+ tem = simplify_gen_unary (NOT, mode, XEXP (op1, 1),
+ GET_MODE (XEXP (op1, 1)));
+ return simplify_gen_binary (AND, mode, op0, tem);
+ }
if (rtx_equal_p (op0, XEXP (op1, 1)))
- return simplify_gen_binary (AND, mode, op0,
- gen_rtx_NOT (mode, XEXP (op1, 0)));
+ {
+ tem = simplify_gen_unary (NOT, mode, XEXP (op1, 0),
+ GET_MODE (XEXP (op1, 0)));
+ return simplify_gen_binary (AND, mode, op0, tem);
+ }
}
break;