summaryrefslogtreecommitdiff
path: root/gcc/tree-inline.c
diff options
context:
space:
mode:
authoraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-15 17:05:19 +0000
committeraoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4>2007-10-15 17:05:19 +0000
commit58047c1717785b31671bb3495ccd64926d36f0f3 (patch)
tree731a989575c8ab26aad22c508cf9f5228d2d8afd /gcc/tree-inline.c
parent6dd98870f89114ea46a2742877ac73210e0b00a3 (diff)
downloadgcc-58047c1717785b31671bb3495ccd64926d36f0f3.tar.gz
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. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@129355 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-inline.c')
-rw-r--r--gcc/tree-inline.c15
1 files changed, 12 insertions, 3 deletions
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 (&copy_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