Hi, when inlining thunks we incorrectly update edge caches of callees. This is because bogus function_symbol call. edge->callee is the inline function body and that is never alias.
Bootstrapped/regtste x86_64-linux, will commit it tomorrow. * ipa-inline.c (report_inline_failed_reason): Look into thunks, too (inline_small_functions): Do not look for function symbol when resetting caches. Index: ipa-inline.c =================================================================== --- ipa-inline.c (revision 236211) +++ ipa-inline.c (working copy) @@ -233,11 +233,11 @@ report_inline_failed_reason (struct cgra if ((e->inline_failed == CIF_TARGET_OPTION_MISMATCH || e->inline_failed == CIF_OPTIMIZATION_MISMATCH) && e->caller->lto_file_data - && e->callee->function_symbol ()->lto_file_data) + && e->callee->ultimate_alias_target ()->lto_file_data) { fprintf (dump_file, " LTO objects: %s, %s\n", e->caller->lto_file_data->file_name, - e->callee->function_symbol ()->lto_file_data->file_name); + e->callee->ultimate_alias_target ()->lto_file_data->file_name); } if (e->inline_failed == CIF_TARGET_OPTION_MISMATCH) cl_target_option_print_diff @@ -2027,7 +2027,7 @@ inline_small_functions (void) inline_call (edge, true, &new_indirect_edges, &overall_size, true); add_new_edges_to_heap (&edge_heap, new_indirect_edges); - reset_edge_caches (edge->callee->function_symbol ()); + reset_edge_caches (edge->callee); update_callee_keys (&edge_heap, where, updated_nodes); }