From: Hans-Peter Nilsson Date: Sun, 31 Mar 2002 15:49:29 +0000 (+0000) Subject: static11.C: Skip on mmix-knuth-mmixware. X-Git-Tag: releases/gcc-3.3.0~5996 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=820ecf563c5338d9978908e4e8fe8cd8a3313d87;p=thirdparty%2Fgcc.git static11.C: Skip on mmix-knuth-mmixware. * g++.old-deja/g++.pt/static11.C: Skip on mmix-knuth-mmixware. * g++.dg/other/static11.C: Copy g++.old-deja/g++.pt/static11.C for -da test. From-SVN: r51656 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index cec193ebe19a..8015ae979302 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2002-03-31 Hans-Peter Nilsson + + * g++.old-deja/g++.pt/static11.C: Skip on mmix-knuth-mmixware. + * g++.dg/other/static11.C: Copy g++.old-deja/g++.pt/static11.C for + -da test. + 2002-03-31 Richard Henderson * gcc.dg/special/alias-2.c: New. diff --git a/gcc/testsuite/g++.dg/other/static11.C b/gcc/testsuite/g++.dg/other/static11.C new file mode 100644 index 000000000000..08126f12c66b --- /dev/null +++ b/gcc/testsuite/g++.dg/other/static11.C @@ -0,0 +1,32 @@ +// This is a copy of g++.old-deja/g++.pt/static11.C which at one +// time got a SEGV for mmix-knuth-mmixware when compiled with +// -da (or either -dj or -df). +// { dg-do compile } +// { dg-options "-da" } + +extern "C" void _exit (int); + +int r = 1; + +struct A +{ + void f(){}; + A(){ ++r; } + ~A(){ r -= 2; _exit (r); } +}; + +template +struct C +{ + C(){ a.f(); } + static A a; +}; + +template A C::a; +typedef C B; + +int main() +{ + C c; + return r; +} diff --git a/gcc/testsuite/g++.old-deja/g++.pt/static11.C b/gcc/testsuite/g++.old-deja/g++.pt/static11.C index 07e6fd71d0b3..cb8a5241a171 100644 --- a/gcc/testsuite/g++.old-deja/g++.pt/static11.C +++ b/gcc/testsuite/g++.old-deja/g++.pt/static11.C @@ -1,5 +1,11 @@ // Bug: g++ was failing to destroy C::a because it was using two // different sentry variables for construction and destruction. +// +// Some targets (e.g. those with "set_board_info needs_status_wrapper 1" +// in their dejagnu baseboard description) require that the status is +// final when exit is entered (or main returns), and not "overruled" by a +// destructor calling _exit. It's not really worth it to handle that. +// Skip if target: mmix-knuth-mmixware extern "C" void _exit (int);