aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/gimple-ssa-store-merging.c4
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/pr87826.c13
4 files changed, 27 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f104208..7b0950c 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2018-11-01 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/87826
+ * gimple-ssa-store-merging.c (do_shift_rotate): Punt if count is
+ negative or larger or equal to type's precision.
+
2018-10-31 Alexandre Oliva <aoliva@redhat.com>
* opts.c (default_options_table): Do not enable
diff --git a/gcc/gimple-ssa-store-merging.c b/gcc/gimple-ssa-store-merging.c
index e1ddcb5..5e5823c 100644
--- a/gcc/gimple-ssa-store-merging.c
+++ b/gcc/gimple-ssa-store-merging.c
@@ -262,7 +262,9 @@ do_shift_rotate (enum tree_code code,
int i, size = TYPE_PRECISION (n->type) / BITS_PER_UNIT;
unsigned head_marker;
- if (count % BITS_PER_UNIT != 0)
+ if (count < 0
+ || count >= TYPE_PRECISION (n->type)
+ || count % BITS_PER_UNIT != 0)
return false;
count = (count / BITS_PER_UNIT) * BITS_PER_MARKER;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 5cb6373..2dbe480 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2018-11-01 Jakub Jelinek <jakub@redhat.com>
+
+ PR tree-optimization/87826
+ * gcc.dg/pr87826.c: New test.
+
2018-11-01 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/46020
diff --git a/gcc/testsuite/gcc.dg/pr87826.c b/gcc/testsuite/gcc.dg/pr87826.c
new file mode 100644
index 0000000..cc5f14a4
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/pr87826.c
@@ -0,0 +1,13 @@
+/* PR tree-optimization/87826 */
+/* { dg-do compile } */
+/* { dg-options "-O3 -w" } */
+
+int c;
+
+void
+foo (int *b)
+{
+ int e;
+ for (e = 0; e < 16; ++e)
+ b[e] = c >> e * 8;
+}