From: Alexandre Oliva Date: Mon, 15 Oct 2007 17:05:19 +0000 (+0000) Subject: re PR middle-end/33706 (gcc_assert failure in verify_eh_edges) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=aa79283408d03841fae2f24d94b5385c978b5a0b;p=gcc.git re PR middle-end/33706 (gcc_assert failure in verify_eh_edges) gcc/ChangeLog: PR middle-end/33706 * tree-inline.c (copy_bb): Use bsi_replace to replace a __builtin_va_arg_pack-containing call stmt. gcc/testsuite/ChangeLog: PR middle-end/33706 * gcc.dg/va-arg-pack-2.c: New. From-SVN: r129355 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index f2849b944cc..f627ef7d157 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2007-10-15 Alexandre Oliva + + PR middle-end/33706 + * tree-inline.c (copy_bb): Use bsi_replace to replace a + __builtin_va_arg_pack-containing call stmt. + 2007-10-15 Razya Ladelsky * matrix-reorg.c (gate_matrix_reorg): Don't comment out whole diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c541b3c8858..7f09cddb89c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-10-15 Alexandre Oliva + + PR middle-end/33706 + * gcc.dg/va-arg-pack-2.c: New. + 2007-10-15 Jakub Jelinek PR tree-optimization/33619 diff --git a/gcc/testsuite/gcc.dg/va-arg-pack-2.c b/gcc/testsuite/gcc.dg/va-arg-pack-2.c new file mode 100644 index 00000000000..417248a2a01 --- /dev/null +++ b/gcc/testsuite/gcc.dg/va-arg-pack-2.c @@ -0,0 +1,17 @@ +/* { dg-do compile } */ +/* { dg-options "-O2" } */ + +extern void noreturn (int status, ...); + +extern inline __attribute ((always_inline)) void +error (int status, ...) +{ + if (__builtin_constant_p (status)) + noreturn (status, __builtin_va_arg_pack ()); +} + +void +f (void) +{ + error (1); +} diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index f575b27b82f..7ebfbcd4a6c 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -863,9 +863,18 @@ copy_bb (copy_body_data *id, basic_block bb, int frequency_scale, int count_scal if (TREE_CODE (*call_ptr) == WITH_SIZE_EXPR) call_ptr = &TREE_OPERAND (*call_ptr, 0); gcc_assert (*call_ptr == call); - *call_ptr = new_call; - stmt = *stmtp; - update_stmt (stmt); + if (call_ptr == stmtp) + { + bsi_replace (©_bsi, new_call, true); + stmtp = bsi_stmt_ptr (copy_bsi); + stmt = *stmtp; + } + else + { + *call_ptr = new_call; + stmt = *stmtp; + update_stmt (stmt); + } } else if (call && id->call_expr