diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8e3fb57dbd4..fe75781ecb9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2018-12-15 Jan Hubicka + + * ipa.c (cgraph_build_static_cdtor_1): Add OPTIMIZATION and TARGET + parameters. + (cgraph_build_static_cdtor): Update. + (build_cdtor): Use OPTIMIZATION and TARGET of the first real cdtor + callsed. + 2018-12-15 Alan Modra * config/rs6000/rs6000.c (generate_set_vrsave, rs6000_emit_savres_rtx), diff --git a/gcc/ipa.c b/gcc/ipa.c index 89fb1da50fd..591634649bf 100644 --- a/gcc/ipa.c +++ b/gcc/ipa.c @@ -831,7 +831,9 @@ ipa_discover_variable_flags (void) be produced. */ static void -cgraph_build_static_cdtor_1 (char which, tree body, int priority, bool final) +cgraph_build_static_cdtor_1 (char which, tree body, int priority, bool final, + tree optimization, + tree target) { static int counter = 0; char which_buf[16]; @@ -862,6 +864,8 @@ cgraph_build_static_cdtor_1 (char which, tree body, int priority, bool final) TREE_STATIC (decl) = 1; TREE_USED (decl) = 1; + DECL_FUNCTION_SPECIFIC_OPTIMIZATION (decl) = optimization; + DECL_FUNCTION_SPECIFIC_TARGET (decl) = target; DECL_ARTIFICIAL (decl) = 1; DECL_IGNORED_P (decl) = 1; DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (decl) = 1; @@ -911,7 +915,7 @@ cgraph_build_static_cdtor_1 (char which, tree body, int priority, bool final) void cgraph_build_static_cdtor (char which, tree body, int priority) { - cgraph_build_static_cdtor_1 (which, body, priority, false); + cgraph_build_static_cdtor_1 (which, body, priority, false, NULL, NULL); } /* When target does not have ctors and dtors, we call all constructor @@ -993,7 +997,9 @@ build_cdtor (bool ctor_p, const vec &cdtors) gcc_assert (body != NULL_TREE); /* Generate a function to call all the function of like priority. */ - cgraph_build_static_cdtor_1 (ctor_p ? 'I' : 'D', body, priority, true); + cgraph_build_static_cdtor_1 (ctor_p ? 'I' : 'D', body, priority, true, + DECL_FUNCTION_SPECIFIC_OPTIMIZATION (cdtors[0]), + DECL_FUNCTION_SPECIFIC_TARGET (cdtors[0])); } }