From: Bernd Edlinger Date: Mon, 4 Jan 2021 10:35:31 +0000 (+0100) Subject: Restore input_location after recursive expand_call_inline X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=6b69738c1e30ec31cb11dce1d9209e7a5b92301b;p=gcc.git Restore input_location after recursive expand_call_inline This is just a precautionary fix. 2021-01-05 Bernd Edlinger * tree-inline.c (expand_call_inline): Restore input_location. Return result from recursive call. --- diff --git a/gcc/tree-inline.c b/gcc/tree-inline.c index de676d418f3..cd3fad1fa98 100644 --- a/gcc/tree-inline.c +++ b/gcc/tree-inline.c @@ -4840,9 +4840,11 @@ expand_call_inline (basic_block bb, gimple *stmt, copy_body_data *id, gimple_call_set_fndecl (stmt, edge->callee->decl); update_stmt (stmt); id->src_node->remove (); - expand_call_inline (bb, stmt, id, to_purge); + successfully_inlined = expand_call_inline (bb, stmt, id, to_purge); maybe_remove_unused_call_args (cfun, stmt); - return true; + /* This used to return true even though we do fail to inline in + some cases. See PR98525. */ + goto egress; } fn = cg_edge->callee->decl; cg_edge->callee->get_untransformed_body ();