aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2006-07-17 08:04:25 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2006-07-17 08:04:25 +0000
commit2b65dae54e6e0eb0a30d645d516a7006d50e321b (patch)
tree0b1589a866d7d8f6ffa994b2f8e67db942d248ff
parent2a50edcd0f5cca974fe82b27a1b109618afa1a05 (diff)
downloadgcc-2b65dae54e6e0eb0a30d645d516a7006d50e321b.zip
gcc-2b65dae54e6e0eb0a30d645d516a7006d50e321b.tar.gz
gcc-2b65dae54e6e0eb0a30d645d516a7006d50e321b.tar.bz2
re PR tree-optimization/28238 (verify_stmts failed (invalid operand to unary operator))
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. * g++.dg/tree-ssa/pr28238.C: New testcase. From-SVN: r115517
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/tree-ssa/pr28238.C22
-rw-r--r--gcc/tree-inline.c8
4 files changed, 42 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 90c8979..8c6048b 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -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...
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 8b6cf37..9b08ae6 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -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
index 0000000..97e388f
--- /dev/null
+++ b/gcc/testsuite/g++.dg/tree-ssa/pr28238.C
@@ -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 ())
+{ }
+
diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c
index 4749be5..92d85a8 100644
--- a/gcc/tree-inline.c
+++ b/gcc/tree-inline.c
@@ -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