aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2015-06-09 12:31:43 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2015-06-09 12:31:43 +0000
commit4ab1e111ef0669bbcbd87a5396d2d209c7e55948 (patch)
tree5f7991776af8f2b6de04c999982dd08a884cd6bd /gcc
parent9aa5f7ec0c0c4045d2a346c4aa90f36642fbb7af (diff)
downloadgcc-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/ChangeLog5
-rw-r--r--gcc/match.pd5
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/fold-modpow2.c11
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" } } */