diff options
author | Richard Biener <rguenther@suse.de> | 2015-06-09 12:31:43 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2015-06-09 12:31:43 +0000 |
commit | 4ab1e111ef0669bbcbd87a5396d2d209c7e55948 (patch) | |
tree | 5f7991776af8f2b6de04c999982dd08a884cd6bd /gcc | |
parent | 9aa5f7ec0c0c4045d2a346c4aa90f36642fbb7af (diff) | |
download | gcc-4ab1e111ef0669bbcbd87a5396d2d209c7e55948.zip gcc-4ab1e111ef0669bbcbd87a5396d2d209c7e55948.tar.gz gcc-4ab1e111ef0669bbcbd87a5396d2d209c7e55948.tar.bz2 |
re PR tree-optimization/66423 (a % (1 << b) no longer gets folded to a & (1 << b) for unsigned a)
2015-06-09 Richard Biener <rguenther@suse.de>
PR middle-end/66423
* match.pd: Handle A % (unsigned)(1 << B).
* gcc.dg/fold-modpow2.c: New testcase.
From-SVN: r224279
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/match.pd | 5 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/fold-modpow2.c | 11 |
4 files changed, 24 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7adf74a..4ad4d66 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2015-06-09 Richard Biener <rguenther@suse.de> + + PR middle-end/66423 + * match.pd: Handle A % (unsigned)(1 << B). + 2015-06-09 Aldy Hernandez <aldyh@redhat.com> * varasm.c (output_object_block_htab): Remove. diff --git a/gcc/match.pd b/gcc/match.pd index abd7851..48a3047 100644 --- a/gcc/match.pd +++ b/gcc/match.pd @@ -248,11 +248,12 @@ along with GCC; see the file COPYING3. If not see (lshift INTEGER_CST@1 @2)) (for mod (trunc_mod floor_mod) (simplify - (mod @0 (power_of_two_cand@1 @2)) + (mod @0 (convert?@3 (power_of_two_cand@1 @2))) (if ((TYPE_UNSIGNED (type) || tree_expr_nonnegative_p (@0)) + && tree_nop_conversion_p (type, TREE_TYPE (@3)) && integer_pow2p (@2) && tree_int_cst_sgn (@2) > 0) - (bit_and @0 (minus @1 { build_int_cst (TREE_TYPE (@1), 1); }))))) + (bit_and @0 (convert (minus @1 { build_int_cst (TREE_TYPE (@1), 1); })))))) /* X % Y is smaller than Y. */ (for cmp (lt ge) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 80fba49..5b5c718 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,10 @@ 2015-06-09 Richard Biener <rguenther@suse.de> + PR middle-end/66423 + * gcc.dg/fold-modpow2.c: New testcase. + +2015-06-09 Richard Biener <rguenther@suse.de> + PR tree-optimization/66419 * gcc.dg/vect/bb-slp-37.c: New testcase. diff --git a/gcc/testsuite/gcc.dg/fold-modpow2.c b/gcc/testsuite/gcc.dg/fold-modpow2.c new file mode 100644 index 0000000..4541b1c --- /dev/null +++ b/gcc/testsuite/gcc.dg/fold-modpow2.c @@ -0,0 +1,11 @@ +/* { dg-do compile } */ +/* { dg-options "-fdump-tree-original" } */ + +unsigned int +my_mod (unsigned int a, unsigned int b) +{ + return a % (1 << b); +} + +/* The above should be simplified to (unsigned int) ((1 << b) + -1) & a */ +/* { dg-final { scan-tree-dump "& a;" "original" } } */ |