Viewing file: pr20126.c (1.12 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* { dg-do run } */ /* { dg-options "-O2" } */
/* PR target/20126 was not really target-specific, but rather a loop's failure to take into account the possibility that a DEST_ADDR giv replacement might fail, such as when you attempt to replace a REG with a PLUS in one of the register_operands of cmpstrqi_rex_1. */
extern void abort (void);
typedef struct { int a; char b[3]; } S; S c = { 2, "aa" }, d = { 2, "aa" };
void * bar (const void *x, int y, int z) { return (void *) 0; }
int foo (S *x, S *y) { const char *e, *f, *g; int h;
h = y->a; f = y->b; e = x->b;
if (h == 1) return bar (e, *f, x->a) != 0;
g = e + x->a - h; while (e <= g) { const char *t = e + 1; /* The pointer E below increases but the bound H stays constant, letting the latter exceed the size remaining in the argument pointed to by the formed, which might be detected by -Wstringop-overread. */ if (__builtin_memcmp (e, f, h) == 0) return 1; e = t; } return 0; }
int main (void) { if (foo (&c, &d) != 1) abort (); return 0; }
/* { dg-prune-output "-Wstringop-overread" } */
|