From 9e6fb77dba8c47d6b6e8792900ab507d60e0bcc1 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Wed, 17 May 2006 17:29:18 +0200 Subject: [PATCH] re PR tree-optimization/27548 (ICE: SSA corruption - Conflict across an abnormal edge) PR tree-optimization/27548 * g++.dg/tree-ssa/pr27548.C: New test. From-SVN: r113864 --- gcc/testsuite/ChangeLog | 5 +++ gcc/testsuite/g++.dg/tree-ssa/pr27548.C | 60 +++++++++++++++++++++++++ 2 files changed, 65 insertions(+) create mode 100644 gcc/testsuite/g++.dg/tree-ssa/pr27548.C diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 5bd9189f676..3fe62f4c58f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-05-17 Jakub Jelinek + + PR tree-optimization/27548 + * g++.dg/tree-ssa/pr27548.C: New test. + 2006-05-17 Francois-Xavier Coudert PR fortran/26551 diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr27548.C b/gcc/testsuite/g++.dg/tree-ssa/pr27548.C new file mode 100644 index 00000000000..d23b959a599 --- /dev/null +++ b/gcc/testsuite/g++.dg/tree-ssa/pr27548.C @@ -0,0 +1,60 @@ +// PR tree-optimization/27548 +// { dg-do compile } +// { dg-options "-O1" } + +namespace Gambit +{ + template < class T > class Array + { + protected:int mindex, maxdex; + T *data; + int InsertAt (const T & t, int n) + { + T *new_data = new T[++this->maxdex - this->mindex + 1] - this->mindex; + int i; + for (i = this->mindex; i <= n - 1; i++) + new_data[i] = this->data[i]; + new_data[i++] = t; + } + public: Array (unsigned int len = 0):mindex (1), maxdex (len), + data ((len) ? new T[len] - + 1 : 0) + { + } + virtual ~ Array () + { + if (maxdex >= mindex) + delete[](data + mindex); + } + const T & operator[] (int index) const + { + } + int Append (const T & t) + { + return InsertAt (t, this->maxdex + 1); + } + }; +} + +class gIndexOdometer +{ +private:Gambit::Array < int >MinIndices; + Gambit::Array < int >CurIndices; + gIndexOdometer (const Gambit::Array < int >, const Gambit::Array < int >); + void SetIndex (const int &, const int &); + int NoIndices () const; + gIndexOdometer AfterExcisionOf (int &) const; +}; +gIndexOdometer +gIndexOdometer::AfterExcisionOf (int &to_be_zapped) const +{ + Gambit::Array < int >NewMins, NewMaxs; + int i; + for (i = 1; i <= NoIndices (); i++) + { + NewMins.Append (MinIndices[i]); + } + gIndexOdometer NewOdo (NewMins, NewMaxs); + for (i = 1; i < to_be_zapped; i++) + NewOdo.SetIndex (i, CurIndices[i]); +}