diff options
Diffstat (limited to 'gcc/testsuite/gcc.dg/pr25682.c')
-rw-r--r-- | gcc/testsuite/gcc.dg/pr25682.c | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/pr25682.c b/gcc/testsuite/gcc.dg/pr25682.c new file mode 100644 index 000000000..8c51d8240 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr25682.c @@ -0,0 +1,28 @@ +/* PR c/25682 */ +/* { dg-do compile } */ +/* { dg-options "-ansi" } */ +/* Test whether we don't ICE on questionable constructs where offsetof + should have been used instead. */ + +struct S +{ + char a[4]; + int b; +}; + +char c[(char *) &((struct S *) 0)->b - (char *) 0]; /* { dg-warning "variably modified" } */ +char d[(__SIZE_TYPE__) &((struct S *) 8)->b]; /* { dg-warning "variably modified" } */ +char e[sizeof (c) == __builtin_offsetof (struct S, b) ? 1 : -1]; +char f[sizeof (d) == __builtin_offsetof (struct S, b) + 8 ? 1 : -1]; + +extern void bar (char *, char *); + +void +foo (void) +{ + char g[(char *) &((struct S *) 0)->b - (char *) 0]; + char h[(__SIZE_TYPE__) &((struct S *) 8)->b]; + char i[sizeof (g) == __builtin_offsetof (struct S, b) ? 1 : -1]; + char j[sizeof (h) == __builtin_offsetof (struct S, b) + 8 ? 1 : -1]; + bar (g, h); +} |