diff options
author | Andrew Pinski <andrew_pinski@playstation.sony.com> | 2008-02-23 17:58:48 +0000 |
---|---|---|
committer | Andrew Pinski <pinskia@gcc.gnu.org> | 2008-02-23 09:58:48 -0800 |
commit | f79db4f66eba251456c2a9c2fc9d0daef1af9e90 (patch) | |
tree | ee2a5464a8fd46288917b5f1ea33c72955e8af86 /gcc | |
parent | bb1f73c2d57ad7e535fe8dbcc52e2d3a3bc680de (diff) | |
download | gcc-f79db4f66eba251456c2a9c2fc9d0daef1af9e90.zip gcc-f79db4f66eba251456c2a9c2fc9d0daef1af9e90.tar.gz gcc-f79db4f66eba251456c2a9c2fc9d0daef1af9e90.tar.bz2 |
re PR tree-optimization/33512 (Simple bitwise simplification missed)
2008-02-23 Andrew Pinski <andrew_pinski@playstation.sony.com>
PR rtl-opt/33512
* simplify-rtx.c (simplify_binary_operation_1): Add simplification
of (and X (ior (not X) Y) and (and (ior (not X) Y) X).
2008-02-23 Andrew Pinski <andrew_pinski@playstation.sony.com>
PR rtl-opt/33512
* gcc.dg/and-1.c: New test.
From-SVN: r132575
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/simplify-rtx.c | 13 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/and-1.c | 10 |
4 files changed, 34 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 235208c..9bf9a9d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,11 @@ 2008-02-23 Andrew Pinski <andrew_pinski@playstation.sony.com> + PR rtl-opt/33512 + * simplify-rtx.c (simplify_binary_operation_1): Add simplification + of (and X (ior (not X) Y) and (and (ior (not X) Y) X). + +2008-02-23 Andrew Pinski <andrew_pinski@playstation.sony.com> + PR pch/35027 * c-pch.c (c_common_valid_pch): Make the "too short to be a PCH file" warning condtional on -Winvalid-PCH. diff --git a/gcc/simplify-rtx.c b/gcc/simplify-rtx.c index f875604..03fbc75 100644 --- a/gcc/simplify-rtx.c +++ b/gcc/simplify-rtx.c @@ -2428,6 +2428,19 @@ simplify_binary_operation_1 (enum rtx_code code, enum machine_mode mode, return simplify_gen_binary (code, mode, tem, op1); } } + + /* (and X (ior (not X) Y) -> (and X Y) */ + if (GET_CODE (op1) == IOR + && GET_CODE (XEXP (op1, 0)) == NOT + && op0 == XEXP (XEXP (op1, 0), 0)) + return simplify_gen_binary (AND, mode, op0, XEXP (op1, 1)); + + /* (and (ior (not X) Y) X) -> (and X Y) */ + if (GET_CODE (op0) == IOR + && GET_CODE (XEXP (op0, 0)) == NOT + && op1 == XEXP (XEXP (op0, 0), 0)) + return simplify_gen_binary (AND, mode, op1, XEXP (op0, 1)); + tem = simplify_associative_operation (code, mode, op0, op1); if (tem) return tem; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index b111ef4..e53852b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2008-02-23 Andrew Pinski <andrew_pinski@playstation.sony.com> + + PR rtl-opt/33512 + * gcc.dg/and-1.c: New test. + 2008-02-23 Daniel Jacobowitz <dan@codesourcery.com> * gcc.c-torture/execute/20080222-1.c: New test. diff --git a/gcc/testsuite/gcc.dg/and-1.c b/gcc/testsuite/gcc.dg/and-1.c new file mode 100644 index 0000000..c66e4e1 --- /dev/null +++ b/gcc/testsuite/gcc.dg/and-1.c @@ -0,0 +1,10 @@ +/* { dg-do compile } */ +/* { dg-options "-O2" } */ +/* { dg-final { scan-assembler "and" { target powerpc*-*-* spu-*-* } } } */ +/* There should be no nand for this testcase (for either PPC or SPU). */ +/* { dg-final { scan-assembler-not "nand" { target powerpc*-*-* spu-*-* } } } */ + +int f(int y) +{ + return y & ~(y & -y); +} |