On Thu, Nov 8, 2018 at 12:39 PM Martin Liška <mli...@suse.cz> wrote:
>
> On 11/8/18 12:19 PM, Jan Hubicka wrote:
> >> Hi.
> >>
> >> In order to fix the warnings mentioned in the PR, we need
> >> to run remove_unreachable_nodes after early tree passes. That's
> >> however possible only within a IPA pass. Thus I'm calling that
> >> before the profile PASS.
> >>
> >> Patch survives regression tests on ppc64le-linux-gnu and majority
> >> of warnings are gone in profiledbootstrap.
> >>
> >> Ready for trunk?
> >
> > I think we want to do that even with no -fprofile-generate because the
> > unreachable code otherwise goes into all other IPA passes for no good
> > reason.  So perhaps adding it as todo after the early optimization
> > metapass?
>
> That fails due to gcc_assert.
> So one needs:
>
> diff --git a/gcc/passes.c b/gcc/passes.c
> index d838d909941..be92a2f3be3 100644
> --- a/gcc/passes.c
> +++ b/gcc/passes.c
> @@ -485,7 +485,7 @@ const pass_data pass_data_all_early_optimizations =
>    0, /* properties_provided */
>    0, /* properties_destroyed */
>    0, /* todo_flags_start */
> -  0, /* todo_flags_finish */
> +  TODO_remove_functions | TODO_rebuild_cgraph_edges, /* todo_flags_finish */
>  };
>
>  class pass_all_early_optimizations : public gimple_opt_pass
> @@ -1989,7 +1989,8 @@ execute_todo (unsigned int flags)
>       of IPA pass queue.  */
>    if (flags & TODO_remove_functions)
>      {
> -      gcc_assert (!cfun);
> +      gcc_assert (!cfun
> +                 || strcmp (current_pass->name, "early_optimizations") == 0);
>        symtab->remove_unreachable_nodes (dump_file);
>      }
>
>
> Or do you prefer to a new pass_remove_functions pass that will be added after
> pass_local_optimization_passes ?

Can you make it todo_flags_start of pass_ipa_tree_profile instead?

> Martin
>
> >
> > Honza
> >> Thanks,
> >> Martin
> >>
> >> gcc/ChangeLog:
> >>
> >> 2018-11-08  Martin Liska  <mli...@suse.cz>
> >>
> >>      * tree-profile.c: Run TODO_remove_functions before "profile"
> >>      pass in order to remove dead functions that will trigger
> >>      -Wmissing-profile.
> >> ---
> >>  gcc/tree-profile.c | 2 +-
> >>  1 file changed, 1 insertion(+), 1 deletion(-)
> >>
> >>
> >
> >> diff --git a/gcc/tree-profile.c b/gcc/tree-profile.c
> >> index d8f2a3b1ba4..c14ebc556a6 100644
> >> --- a/gcc/tree-profile.c
> >> +++ b/gcc/tree-profile.c
> >> @@ -776,7 +776,7 @@ const pass_data pass_data_ipa_tree_profile =
> >>    0, /* properties_required */
> >>    0, /* properties_provided */
> >>    0, /* properties_destroyed */
> >> -  0, /* todo_flags_start */
> >> +  TODO_remove_functions, /* todo_flags_start */
> >>    TODO_dump_symtab, /* todo_flags_finish */
> >>  };
> >>
> >>
> >
>

Reply via email to