diff options
Diffstat (limited to 'gcc/ipa-inline.c')
-rw-r--r-- | gcc/ipa-inline.c | 79 |
1 files changed, 47 insertions, 32 deletions
diff --git a/gcc/ipa-inline.c b/gcc/ipa-inline.c index e79a4dd8e21..f0177dfc60d 100644 --- a/gcc/ipa-inline.c +++ b/gcc/ipa-inline.c @@ -122,6 +122,7 @@ along with GCC; see the file COPYING3. If not see #include "ipa-inline.h" #include "ipa-utils.h" #include "sreal.h" +#include "auto-profile.h" #include "cilk.h" #include "builtins.h" @@ -443,6 +444,14 @@ want_early_inline_function_p (struct cgraph_edge *e) if (DECL_DISREGARD_INLINE_LIMITS (callee->decl)) ; + /* For AutoFDO, we need to make sure that before profile annotation, all + hot paths' IR look exactly the same as profiled binary. As a result, + in einliner, we will disregard size limit and inline those callsites + that are: + * inlined in the profiled binary, and + * the cloned callee has enough samples to be considered "hot". */ + else if (flag_auto_profile && afdo_callsite_hot_enough_for_early_inline (e)) + ; else if (!DECL_DECLARED_INLINE_P (callee->decl) && !flag_inline_small_functions) { @@ -2360,39 +2369,8 @@ early_inline_small_functions (struct cgraph_node *node) return inlined; } -/* Do inlining of small functions. Doing so early helps profiling and other - passes to be somewhat more effective and avoids some code duplication in - later real inlining pass for testcases with very many function calls. */ - -namespace { - -const pass_data pass_data_early_inline = -{ - GIMPLE_PASS, /* type */ - "einline", /* name */ - OPTGROUP_INLINE, /* optinfo_flags */ - TV_EARLY_INLINING, /* tv_id */ - PROP_ssa, /* properties_required */ - 0, /* properties_provided */ - 0, /* properties_destroyed */ - 0, /* todo_flags_start */ - 0, /* todo_flags_finish */ -}; - -class pass_early_inline : public gimple_opt_pass -{ -public: - pass_early_inline (gcc::context *ctxt) - : gimple_opt_pass (pass_data_early_inline, ctxt) - {} - - /* opt_pass methods: */ - virtual unsigned int execute (function *); - -}; // class pass_early_inline - unsigned int -pass_early_inline::execute (function *fun) +early_inliner (function *fun) { struct cgraph_node *node = cgraph_node::get (current_function_decl); struct cgraph_edge *edge; @@ -2493,6 +2471,43 @@ pass_early_inline::execute (function *fun) return todo; } +/* Do inlining of small functions. Doing so early helps profiling and other + passes to be somewhat more effective and avoids some code duplication in + later real inlining pass for testcases with very many function calls. */ + +namespace { + +const pass_data pass_data_early_inline = +{ + GIMPLE_PASS, /* type */ + "einline", /* name */ + OPTGROUP_INLINE, /* optinfo_flags */ + TV_EARLY_INLINING, /* tv_id */ + PROP_ssa, /* properties_required */ + 0, /* properties_provided */ + 0, /* properties_destroyed */ + 0, /* todo_flags_start */ + 0, /* todo_flags_finish */ +}; + +class pass_early_inline : public gimple_opt_pass +{ +public: + pass_early_inline (gcc::context *ctxt) + : gimple_opt_pass (pass_data_early_inline, ctxt) + {} + + /* opt_pass methods: */ + virtual unsigned int execute (function *); + +}; // class pass_early_inline + +unsigned int +pass_early_inline::execute (function *fun) +{ + return early_inliner (fun); +} + } // anon namespace gimple_opt_pass * |