PR middle-end/37393
authorjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 8 Sep 2008 21:31:36 +0000 (21:31 +0000)
committerjakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4>
Mon, 8 Sep 2008 21:31:36 +0000 (21:31 +0000)
* tree-inline.c (copy_bb): When replacing a gimple_call_va_arg_pack_p
call stmt by new_call, clear gimple_bb on stmt after gsi_replace.

* g++.dg/tree-ssa/pr37393.C: New test.

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

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

index 60ff6e9..d5c28ee 100644 (file)
@@ -1,5 +1,9 @@
 2008-09-08  Jakub Jelinek  <jakub@redhat.com>
 
+       PR middle-end/37393
+       * tree-inline.c (copy_bb): When replacing a gimple_call_va_arg_pack_p
+       call stmt by new_call, clear gimple_bb on stmt after gsi_replace.
+
        PR middle-end/37414
        * predict.c (optimize_function_for_size_p): Don't segfault if
        FUN is NULL.
index f5aec00..d8e5716 100644 (file)
@@ -1,5 +1,8 @@
 2008-09-08  Jakub Jelinek  <jakub@redhat.com>
 
+       PR middle-end/37393
+       * g++.dg/tree-ssa/pr37393.C: New test.
+
        PR middle-end/37414
        * g++.dg/opt/init2.C: New test.
 
diff --git a/gcc/testsuite/g++.dg/tree-ssa/pr37393.C b/gcc/testsuite/g++.dg/tree-ssa/pr37393.C
new file mode 100644 (file)
index 0000000..2f9281c
--- /dev/null
@@ -0,0 +1,27 @@
+// PR middle-end/37393
+// { dg-do compile }
+// { dg-options "-O2" }
+
+struct A
+{
+  ~A ();
+  bool foo () const;
+};
+
+extern "C"
+{
+  extern void bar (const char *, ...) __attribute__ ((noreturn));
+  extern inline __attribute__ ((always_inline, gnu_inline, artificial)) void
+  baz (const char *fmt, ...)
+  {
+    bar (fmt, __builtin_va_arg_pack ());
+  }
+};
+
+void
+test ()
+{
+  A a;
+  if (a.foo ())
+    baz ("foo");
+}
index 8b603f0..d083a54 100644 (file)
@@ -1331,6 +1331,7 @@ copy_bb (copy_body_data *id, basic_block bb, int frequency_scale,
              gimple_call_set_lhs (new_call, gimple_call_lhs (stmt));
 
              gsi_replace (&copy_gsi, new_call, false);
+             gimple_set_bb (stmt, NULL);
              stmt = new_call;
            }
          else if (is_gimple_call (stmt)