From 297a777d4748114bc58d17eb41d7b8026f20a711 Mon Sep 17 00:00:00 2001 From: Andreas Krebbel Date: Wed, 9 Nov 2005 11:42:38 +0000 Subject: s390.c (s390_regs_ever_clobbered): Only save live eh regs for a function containing a landing pad. 2005-11-09 Andreas Krebbel * config/s390/s390.c (s390_regs_ever_clobbered): Only save live eh regs for a function containing a landing pad. * testsuite/g++.dg/other/pr24623.C: Testcase added. From-SVN: r106687 --- gcc/testsuite/g++.dg/other/pr24623.C | 69 ++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100644 gcc/testsuite/g++.dg/other/pr24623.C (limited to 'gcc/testsuite/g++.dg') diff --git a/gcc/testsuite/g++.dg/other/pr24623.C b/gcc/testsuite/g++.dg/other/pr24623.C new file mode 100644 index 0000000..480bb39 --- /dev/null +++ b/gcc/testsuite/g++.dg/other/pr24623.C @@ -0,0 +1,69 @@ +/* This used to ICE due to a backend problem on s390. */ + +/* { dg-do compile } */ +/* { dg-options "-O1" } */ + +class ReferenceCounted +{ +public: + + virtual ~ ReferenceCounted () + { + } + void decrementRefCount () const + { + if (--const_cast < unsigned int &>(_ref_count) == 0) + { + delete this; + } + } + unsigned int _ref_count; +}; + +template < class T > class RefCountPointer +{ +public: + +RefCountPointer (T * p = 0):_p (p) + { + } + RefCountPointer & operator= (const RefCountPointer < T > &o) + { + if (_p != o._p) + { + if (_p != 0) + _p->decrementRefCount (); + } + } + ~RefCountPointer () + { + } + T *_p; +}; +class Item:public ReferenceCounted +{ +public: + + typedef RefCountPointer < const Item > Ptr; +}; +class AnyAtomicType:public Item +{ +}; +class StaticContext +{ +}; +class DynamicContext:public StaticContext +{ +}; +class SortableItem +{ + SortableItem (); + int m_bAscending:1; + DynamicContext *m_context; + AnyAtomicType::Ptr m_item; +}; +SortableItem::SortableItem () +{ + m_context = __null; + m_item = __null; +} -- cgit v1.1