Skip to content

Commit

Permalink
PR tree-optimization/86196 - Bogus -Wrestrict on memcpy between array…
Browse files Browse the repository at this point in the history
… elements at unequal indices

gcc/ChangeLog:

	PR tree-optimization/86196
	* gimple-ssa-warn-restrict.c (builtin_memref::builtin_memref): Use
	base size only of arrays.

gcc/testsuite/ChangeLog:

	PR tree-optimization/86196
	* gcc.dg/Wrestrict-18.c: New test.

From-SVN: r266967
  • Loading branch information
Martin Sebor authored and Martin Sebor committed Dec 11, 2018
1 parent 03da9b7 commit 1486eb7
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 9 deletions.
6 changes: 6 additions & 0 deletions gcc/ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
2018-12-10 Martin Sebor <[email protected]>

PR tree-optimization/86196
* gimple-ssa-warn-restrict.c (builtin_memref::builtin_memref): Use
base size only of arrays.

2018-12-10 Segher Boessenkool <[email protected]>

* config.gcc (Obsolete configurations): Delete powerpc*-*-*spe*.
Expand Down
19 changes: 10 additions & 9 deletions gcc/gimple-ssa-warn-restrict.c
Original file line number Diff line number Diff line change
Expand Up @@ -272,15 +272,16 @@ builtin_memref::builtin_memref (tree expr, tree size)

offset_int maxoff = maxobjsize;
tree basetype = TREE_TYPE (base);
if (TREE_CODE (basetype) == ARRAY_TYPE
&& ref
&& array_at_struct_end_p (ref))
; /* Use the maximum possible offset for last member arrays. */
else if (tree basesize = TYPE_SIZE_UNIT (basetype))
if (TREE_CODE (basesize) == INTEGER_CST)
/* Size could be non-constant for a variable-length type such
as a struct with a VLA member (a GCC extension). */
maxoff = wi::to_offset (basesize);
if (TREE_CODE (basetype) == ARRAY_TYPE)
{
if (ref && array_at_struct_end_p (ref))
; /* Use the maximum possible offset for last member arrays. */
else if (tree basesize = TYPE_SIZE_UNIT (basetype))
if (TREE_CODE (basesize) == INTEGER_CST)
/* Size could be non-constant for a variable-length type such
as a struct with a VLA member (a GCC extension). */
maxoff = wi::to_offset (basesize);
}

if (offrange[0] >= 0)
{
Expand Down
6 changes: 6 additions & 0 deletions gcc/testsuite/ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
2018-12-10 Martin Sebor <[email protected]>

PR tree-optimization/86196
* gimple-ssa-warn-restrict.c (builtin_memref::builtin_memref): Use
base size only of arrays.

2018-12-10 Uros Bizjak <[email protected]>

* gcc.dg/sinatan-1.c: Use dg-add-options ieee.
Expand Down
37 changes: 37 additions & 0 deletions gcc/testsuite/gcc.dg/Wrestrict-18.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
/* PR tree-optimization/86196 - Bogus -Wrestrict on memcpy between array
elements at unequal indices
{ dg-do compile }
{ dg-options "-O2 -Wall" } */

typedef __SIZE_TYPE__ size_t;

extern void* memcpy (void*, const void*, size_t);

struct S
{
int n;
void * p;
};

/* Test case submitted in the PR. */

void pr86196_c0 (struct S * a, size_t n)
{
for (size_t i = 0, j = 0; i != n; ++i)
{
if (a[i].n == 0)
{
if (i != j)
memcpy (&a[j], &a[i], sizeof (struct S)); /* { dg-bogus "\\\[-Wrestrict" } */
++j;
}
}
}

/* Reduced test case. */

void pr86196_c1 (struct S *a, int i, int j)
{
if (i != j)
memcpy (&a[j], &a[i], sizeof (struct S)); /* { dg-bogus "\\\[-Wrestrict" } */
}

0 comments on commit 1486eb7

Please sign in to comment.