blob: a00debf358833ef8de1f2b6ba9d50a2d68c86296 [file] [log] [blame]
/* { dg-do run } */
/* { dg-require-effective-target fstack_protector } */
/* { dg-options "-fstack-protector-strong" } */
/* { dg-set-target-env-var ASAN_OPTIONS "detect_stack_use_after_return=1" } */
/* { dg-shouldfail "asan" } */
__attribute__((noinline))
char *Ident(char *x) {
return x;
}
__attribute__((noinline))
char *Func1() {
char local[1 << 12];
return Ident(local);
}
__attribute__((noinline))
void Func2(char *x) {
*x = 1;
}
int main(int argc, char **argv) {
Func2(Func1());
return 0;
}
/* { dg-output "AddressSanitizer: stack-use-after-return on address 0x\[0-9a-f\]+\[^\n\r]*(\n|\r\n|\r)" } */
/* { dg-output "WRITE of size 1 at .* thread T0.*" } */
/* { dg-output " #0.*(Func2)?.*pr64820.(c:21)?.*" } */
/* { dg-output "is located in stack of thread T0 at offset.*" } */
/* { dg-output "\'local\' \\(line 14\\) <== Memory access at offset 32 is inside this variable" } */