From c8df72c446639286815357b723f257264e6b6162 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 4 Feb 2019 09:52:18 +0100 Subject: [PATCH] * g++.dg/torture/alias-1.C: New test. From-SVN: r268510 --- gcc/testsuite/ChangeLog | 4 ++ gcc/testsuite/g++.dg/torture/alias-1.C | 57 ++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 gcc/testsuite/g++.dg/torture/alias-1.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c186df74d48..e2b024302c7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2019-02-04 Jakub Jelinek + + * g++.dg/torture/alias-1.C: New test. + 2019-02-03 Martin Sebor PR c/69661 diff --git a/gcc/testsuite/g++.dg/torture/alias-1.C b/gcc/testsuite/g++.dg/torture/alias-1.C new file mode 100644 index 00000000000..2abe5438510 --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/alias-1.C @@ -0,0 +1,57 @@ +// Verify we don't try to allocate the same stack slot for +// buf1 and buf2 in qux. While there is a CLOBBER stmt for buf1 +// from inlined destructor, the buf1 variable doesn't go out of scope +// until after the baz call. +// { dg-do run } + +#include +#include +#include + +char *p; +struct S { char buf[128]; S () { memset (buf, ' ', 128); }; ~S () {}; }; + +__attribute__((noipa)) void +foo (char *x) +{ + p = x; +} + +__attribute__((noipa)) int +bar (S *x) +{ + return x->buf[12]; +} + +__attribute__((noipa)) void +baz (char *x) +{ + S *a = new (p) (S); + S *b = new (x) (S); + memset (a->buf, '0', 128); + memset (b->buf, '1', 128); + if (bar (a) != '0' || bar (b) != '1') + abort (); + b->~S (); + a->~S (); +} + +__attribute__((noipa)) void +qux () +{ + char buf1[128]; + foo (buf1); + S *p = new (buf1) (S); + bar (p); + p->~S (); + { + char buf2[128]; + baz (buf2); + } +} + +int +main () +{ + qux (); +} -- 2.30.2