]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR tree-optimization/50763 (ICE: verify_gimple failed: missing PHI def with -ftree...
authorTom de Vries <tom@codesourcery.com>
Fri, 4 Nov 2011 10:56:39 +0000 (10:56 +0000)
committerTom de Vries <vries@gcc.gnu.org>
Fri, 4 Nov 2011 10:56:39 +0000 (10:56 +0000)
2011-11-04  Tom de Vries  <tom@codesourcery.com>

PR tree-optimization/50763
* g++.dg/pr50763-4.C: New test.

From-SVN: r180936

gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/pr50763-4.C [new file with mode: 0644]

index f17ff70ec74cea01f4e986efe769ef3cb84da599..fd2cfacf8ba4e80a800273d0412d2f1802e0c0ca 100644 (file)
@@ -1,3 +1,8 @@
+2011-11-04  Tom de Vries  <tom@codesourcery.com>
+
+       PR tree-optimization/50763
+       * g++.dg/pr50763-4.C: New test.
+
 2011-11-04  Jakub Jelinek  <jakub@redhat.com>
 
        * gcc.dg/torture/vec-cvt-1.c: Enable commented out inttoflttestui
diff --git a/gcc/testsuite/g++.dg/pr50763-4.C b/gcc/testsuite/g++.dg/pr50763-4.C
new file mode 100644 (file)
index 0000000..2605d81
--- /dev/null
@@ -0,0 +1,34 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -ftree-tail-merge" } */
+
+float
+clamp (const float x)
+{
+  return x <= 1 ? 1 : x;
+}
+
+template < class T > struct VECTOR
+{
+  float x;
+};
+template < class TV > class JOINT
+{
+  virtual void Constrain_Angles (VECTOR < float >&angles) const;
+};
+
+template < class TV > class ANGLE_JOINT:public JOINT < TV >
+{
+  virtual ~ ANGLE_JOINT ()
+  {
+  }
+  void Constrain_Angles (VECTOR < float >&angles) const
+  {
+    VECTOR < float >v;
+    if (v.x)
+        v.x = clamp (angles.x);
+    else
+        v.x = angles.x;
+      angles.x = v.x;
+  }
+};
+template ANGLE_JOINT < int >::~ANGLE_JOINT ();