re PR middle-end/55331 (ICE: SIGSEGV in substitute_and_fold with -O2 -fno-tree-fre)
authorRichard Biener <rguenther@suse.de>
Tue, 27 Nov 2012 09:20:02 +0000 (09:20 +0000)
committerRichard Biener <rguenth@gcc.gnu.org>
Tue, 27 Nov 2012 09:20:02 +0000 (09:20 +0000)
2012-11-27  Richard Biener  <rguenther@suse.de>

PR middle-end/55331
* gimple-fold.c (gimplify_and_update_call_from_tree): Replace
stmt with a NOP instead of removing it.

* g++.dg/opt/pr55331.C: New testcase.

From-SVN: r193839

gcc/ChangeLog
gcc/gimple-fold.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/opt/pr55331.C [new file with mode: 0644]

index 1274fb18a9ea4aa9c2e3174d1868c7058951da76..4aab7fceda2b9e4600e18a9c477951608a2ade85 100644 (file)
@@ -1,3 +1,9 @@
+2012-11-27  Richard Biener  <rguenther@suse.de>
+
+       PR middle-end/55331
+       * gimple-fold.c (gimplify_and_update_call_from_tree): Replace
+       stmt with a NOP instead of removing it.
+
 2012-11-27  Steven Bosscher  <steven@gcc.gnu.org>
 
        * loop-invariant.c (check_invariant_table_size): Take sizeof of
index 969cfeb582929315cdaeeb2c89ebc78fba2e8556..251be2485d4d9d02e76c2a59d97156386c527106 100644 (file)
@@ -607,7 +607,7 @@ gimplify_and_update_call_from_tree (gimple_stmt_iterator *si_p, tree expr)
              unlink_stmt_vdef (stmt);
              release_defs (stmt);
            }
-         gsi_remove (si_p, true);
+         gsi_replace (si_p, gimple_build_nop (), true);
          return;
        }
     }
index 0164d27573625e67b65f0663864c0819cf7aede7..ff025c11e53ac3ec3ec544dc29293d3ad6628a15 100644 (file)
@@ -1,3 +1,8 @@
+2012-11-27  Richard Biener  <rguenther@suse.de>
+
+       PR middle-end/55331
+       * g++.dg/opt/pr55331.C: New testcase.
+
 2012-11-26  Steven Bosscher  <steven@gcc.gnu.org>
 
        * gcc.dg/20050811-2.c: Change -dv option to -graph option.
diff --git a/gcc/testsuite/g++.dg/opt/pr55331.C b/gcc/testsuite/g++.dg/opt/pr55331.C
new file mode 100644 (file)
index 0000000..4717db8
--- /dev/null
@@ -0,0 +1,14 @@
+// PR tree-optimization/55331
+// { dg-do compile }
+// { dg-options "-O2 -fno-tree-fre" }
+
+struct A {};
+
+void
+foo (A *p, bool x)
+{
+  A a;
+  char *e = (char *) (&a + 1);
+  if (x)
+    __builtin_memmove (p, &a, e - (char *) &a);
+}