summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.dg/eh/stabilize.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/g++.dg/eh/stabilize.C')
-rw-r--r--gcc/testsuite/g++.dg/eh/stabilize.C26
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.dg/eh/stabilize.C b/gcc/testsuite/g++.dg/eh/stabilize.C
new file mode 100644
index 000000000..df47cab0c
--- /dev/null
+++ b/gcc/testsuite/g++.dg/eh/stabilize.C
@@ -0,0 +1,26 @@
+// PR c++/8186
+
+// Bug: In f, convert_for_arg_passing wrapped the A TARGET_EXPR in an
+// ADDR_EXPR for passing by invisible ref. stabilize_throw_expr copied the
+// resulting pointer into a temporary. cp_convert_parm_for_inlining then
+// dereferences it and tries to initialize B::am with the INDIRECT_REF,
+// which calls for a bitwise copy. Which is broken.
+
+// { dg-options "-O" }
+
+struct A
+{
+ A();
+ A(const A&);
+ A& operator=(const A&);
+};
+
+struct B {
+ A am;
+ B(A a) { am = a; }
+};
+
+void f ()
+{
+ throw B(A());
+}