1 /* { dg-do run { target { i?86-*-linux* i?86-*-gnu* x86_64-*-linux* } } } */
2 /* { dg-require-effective-target cet } */
3 /* { dg-require-effective-target split_stack } */
4 /* { dg-options "-fsplit-stack -O2 -fcf-protection" } */
5 /* { dg-options "-fsplit-stack -O2 -mno-accumulate-outgoing-args -fcf-protection" { target { { i?86-*-* x86_64-*-* } && ia32 } } } */
7 /* A case that used to fail on 32-bit x86 when optimizing and not
8 using -maccumulate-args. The stack adjustment of the alloca got
9 mixed up with the arguments pushed on the stack to the function
10 before the call of alloca. */
14 typedef struct { const char* s
; int l
; } s
;
16 typedef unsigned long long align16
__attribute__ ((aligned(16)));
18 s
gobats (const void *, int) __attribute__ ((noinline
));
21 gobats (const void* p
__attribute__ ((unused
)),
22 int l
__attribute__ ((unused
)))
30 void check_aligned (void *p
) __attribute__ ((noinline
));
33 check_aligned (void *p
)
35 if (((__SIZE_TYPE__
) p
& 0xf) != 0)
39 void gap (void *) __attribute__ ((noinline
));
48 main (int argc
, char **argv
)
52 space
= (s
*) alloca(sizeof(s
) + 1);