OSDN Git Service

2006-07-17 Richard Guenther <rguenther@suse.de>
authorrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 17 Jul 2006 08:04:25 +0000 (08:04 +0000)
committerrguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 17 Jul 2006 08:04:25 +0000 (08:04 +0000)
PR tree-optimization/28238
* tree-inline.c (copy_bb): Check if we produced valid
gimple copying and substituting a stmt.  If not, gimplify
it.

* g++.dg/tree-ssa/pr28238.C: New testcase.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@115517 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/tree-ssa/pr28238.C [new file with mode: 0644]
gcc/tree-inline.c

index 90c8979..8c6048b 100644 (file)
@@ -1,3 +1,10 @@
+2006-07-17  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/28238
+       * tree-inline.c (copy_bb): Check if we produced valid
+       gimple copying and substituting a stmt.  If not, gimplify
+       it.
+
 2006-07-16  Eric Botcazou  <ebotcazou@adacore.com>
 
        * optabs.c (maybe_encapsulate_block): New function extracted from...
index 8b6cf37..9b08ae6 100644 (file)
@@ -1,3 +1,8 @@
+2006-07-17  Richard Guenther  <rguenther@suse.de>
+
+       PR tree-optimization/28238
+       * g++.dg/tree-ssa/pr28238.C: New testcase.
+
 2006-07-17  Volker Reichelt  <reichelt@igpm.rwth-aachen.de>
 
        PR c++/28250
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr28238.C b/gcc/testsuite/g++.dg/tree-ssa/pr28238.C
new file mode 100644 (file)
index 0000000..97e388f
--- /dev/null
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-options "-O" } */
+
+struct iterator{};
+struct ByteIterator : iterator
+{
+        ByteIterator (){}
+        int a[1024];
+};
+inline ByteIterator f ()
+{
+        return  ByteIterator ();
+}
+class ConfLexerCore
+{
+        ConfLexerCore ();
+        ByteIterator m_matchStart;
+};
+ConfLexerCore::ConfLexerCore ()
+: m_matchStart (f ())
+{ }
+
index 4749be5..92d85a8 100644 (file)
@@ -704,6 +704,14 @@ copy_bb (copy_body_data *id, basic_block bb, int frequency_scale, int count_scal
       if (stmt)
        {
          tree call, decl;
+
+         /* With return slot optimization we can end up with
+            non-gimple (foo *)&this->m, fix that here.  */
+         if (TREE_CODE (stmt) == MODIFY_EXPR
+             && TREE_CODE (TREE_OPERAND (stmt, 1)) == NOP_EXPR
+             && !is_gimple_val (TREE_OPERAND (TREE_OPERAND (stmt, 1), 0)))
+           gimplify_stmt (&stmt);
+
           bsi_insert_after (&copy_bsi, stmt, BSI_NEW_STMT);
          call = get_call_expr_in (stmt);
          /* We're duplicating a CALL_EXPR.  Find any corresponding