re PR tree-optimization/87826 (ubsan: gimple-ssa-store-merging.c:281)

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.

	* gcc.dg/pr87826.c: New test.

From-SVN: r265720
This commit is contained in:
Jakub Jelinek 2018-11-01 13:31:45 +01:00 committed by Jakub Jelinek
parent 86ba9ce626
commit 444cda7470
4 changed files with 27 additions and 1 deletions

View file

@ -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

View file

@ -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;

View file

@ -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

View file

@ -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;
}