Hi, now when we actually have quality tracking, we should use it. Bootstrapped/regtested x86_64-linux, comitted.
Honza * auto-profile.c (afdo_set_bb_count, afdo_propagate_edge, afdo_annotate_cfg): Set counts/probabilities as determined by afdo. Index: auto-profile.c =================================================================== --- auto-profile.c (revision 250021) +++ auto-profile.c (working copy) @@ -1151,7 +1151,7 @@ afdo_set_bb_count (basic_block bb, const FOR_EACH_EDGE (e, ei, bb->succs) afdo_source_profile->mark_annotated (e->goto_locus); - bb->count = profile_count::from_gcov_type (max_count); + bb->count = profile_count::from_gcov_type (max_count).afdo (); return true; } @@ -1228,7 +1228,7 @@ afdo_propagate_edge (bool is_succ, bb_se edge e, unknown_edge = NULL; edge_iterator ei; int num_unknown_edge = 0; - profile_count total_known_count = profile_count::zero (); + profile_count total_known_count = profile_count::zero ().afdo (); FOR_EACH_EDGE (e, ei, is_succ ? bb->succs : bb->preds) if (!is_edge_annotated (e, *annotated_edge)) @@ -1350,7 +1350,7 @@ afdo_propagate_circuit (const bb_set &an && !is_edge_annotated (ep, *annotated_edge)) { ep->probability = profile_probability::never (); - ep->count = profile_count::zero (); + ep->count = profile_count::zero ().afdo (); set_edge_annotated (ep, annotated_edge); } } @@ -1537,9 +1537,9 @@ afdo_annotate_cfg (const stmt_set &promo if (s == NULL) return; cgraph_node::get (current_function_decl)->count - = profile_count::from_gcov_type (s->head_count ()); + = profile_count::from_gcov_type (s->head_count ()).afdo (); ENTRY_BLOCK_PTR_FOR_FN (cfun)->count - = profile_count::from_gcov_type (s->head_count ()); + = profile_count::from_gcov_type (s->head_count ()).afdo (); profile_count max_count = ENTRY_BLOCK_PTR_FOR_FN (cfun)->count; FOR_EACH_BB_FN (bb, cfun)