From: jakub Date: Thu, 5 Feb 2009 21:54:06 +0000 (+0000) Subject: PR c++/39106 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f014e39d49d0f72c4ec12c0b3a6ff21c40349088;p=thirdparty%2Fgcc.git PR c++/39106 * cgraphunit.c (cgraph_function_versioning): Clear also DECL_VIRTUAL_P on the copied decl. * g++.dg/opt/thunk3.C: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@143973 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index a8d6685bd628..92bb49ce5424 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2009-02-05 Jakub Jelinek + + PR c++/39106 + * cgraphunit.c (cgraph_function_versioning): Clear also DECL_VIRTUAL_P + on the copied decl. + 2009-02-05 Paolo Bonzini PR rtl-optimization/39110 diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index cd58c2aae0b3..586ed61c2ae3 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -1551,10 +1551,11 @@ cgraph_function_versioning (struct cgraph_node *old_version_node, TREE_PUBLIC (new_version_node->decl) = 0; DECL_COMDAT (new_version_node->decl) = 0; DECL_WEAK (new_version_node->decl) = 0; + DECL_VIRTUAL_P (new_version_node->decl) = 0; new_version_node->local.externally_visible = 0; new_version_node->local.local = 1; new_version_node->lowered = true; - + /* Update the call_expr on the edges to call the new version node. */ update_call_expr (new_version_node); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 6299f28c4092..dc1c009881e4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-02-05 Jakub Jelinek + + PR c++/39106 + * g++.dg/opt/thunk3.C: New test. + 2009-02-05 Nick Clifton * gcc.c-torture/compile/20080625-1.c: Skip for M32C. diff --git a/gcc/testsuite/g++.dg/opt/thunk3.C b/gcc/testsuite/g++.dg/opt/thunk3.C new file mode 100644 index 000000000000..bfd68744ade6 --- /dev/null +++ b/gcc/testsuite/g++.dg/opt/thunk3.C @@ -0,0 +1,48 @@ +// PR c++/39106 +// { dg-do compile } +// { dg-options "-O2" } + +extern "C" void abort (); + +struct A +{ + A (bool x = true); +}; +class B +{ + virtual bool bar (A &, int) const =0; +}; +class C : virtual public B +{ +}; +struct D : virtual public B +{ + bool bar (A &, int) const; +}; +template +struct E : public D +{ + bool bar (A &x, int y) const + { + return baz().bar (x, y); + } + const D & baz () const; +}; +extern template class E<0>; + +void +foo () +{ + try + { + A a; + abort (); + } catch (...) + { + } + A b; + E<0> c; + c.bar (b, 3); + E<0> d; + d.bar (b, 3); +}