1 /* Definitions for branch prediction routines in the GNU compiler.
2 Copyright (C) 2001-2017 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
23 #include "profile-count.h"
25 /* Random guesstimation given names.
26 PROB_VERY_UNLIKELY should be small enough so basic block predicted
27 by it gets below HOT_BB_FREQUENCY_FRACTION. */
28 #define PROB_VERY_UNLIKELY (REG_BR_PROB_BASE / 2000 - 1)
29 #define PROB_EVEN (REG_BR_PROB_BASE / 2)
30 #define PROB_VERY_LIKELY (REG_BR_PROB_BASE - PROB_VERY_UNLIKELY)
31 #define PROB_ALWAYS (REG_BR_PROB_BASE)
32 #define PROB_UNLIKELY (REG_BR_PROB_BASE / 5 - 1)
33 #define PROB_LIKELY (REG_BR_PROB_BASE - PROB_UNLIKELY)
35 #define DEF_PREDICTOR(ENUM, NAME, HITRATE, FLAGS) ENUM,
38 #include "predict.def"
40 /* Upper bound on non-language-specific builtins. */
50 extern gcov_type
get_hot_bb_threshold (void);
51 extern void set_hot_bb_threshold (gcov_type
);
52 extern bool maybe_hot_count_p (struct function
*, profile_count
);
53 extern bool maybe_hot_bb_p (struct function
*, const_basic_block
);
54 extern bool maybe_hot_edge_p (edge
);
55 extern bool probably_never_executed_bb_p (struct function
*, const_basic_block
);
56 extern bool probably_never_executed_edge_p (struct function
*, edge
);
57 extern bool optimize_function_for_size_p (struct function
*);
58 extern bool optimize_function_for_speed_p (struct function
*);
59 extern optimization_type
function_optimization_type (struct function
*);
60 extern bool optimize_bb_for_size_p (const_basic_block
);
61 extern bool optimize_bb_for_speed_p (const_basic_block
);
62 extern optimization_type
bb_optimization_type (const_basic_block
);
63 extern bool optimize_edge_for_size_p (edge
);
64 extern bool optimize_edge_for_speed_p (edge
);
65 extern bool optimize_insn_for_size_p (void);
66 extern bool optimize_insn_for_speed_p (void);
67 extern bool optimize_loop_for_size_p (struct loop
*);
68 extern bool optimize_loop_for_speed_p (struct loop
*);
69 extern bool optimize_loop_nest_for_speed_p (struct loop
*);
70 extern bool optimize_loop_nest_for_size_p (struct loop
*);
71 extern bool predictable_edge_p (edge
);
72 extern void rtl_profile_for_bb (basic_block
);
73 extern void rtl_profile_for_edge (edge
);
74 extern void default_rtl_profile (void);
75 extern bool rtl_predicted_by_p (const_basic_block
, enum br_predictor
);
76 extern bool gimple_predicted_by_p (const_basic_block
, enum br_predictor
);
77 extern bool edge_probability_reliable_p (const_edge
);
78 extern bool br_prob_note_reliable_p (const_rtx
);
79 extern void predict_insn_def (rtx_insn
*, enum br_predictor
, enum prediction
);
80 extern void rtl_predict_edge (edge
, enum br_predictor
, int);
81 extern void gimple_predict_edge (edge
, enum br_predictor
, int);
82 extern void remove_predictions_associated_with_edge (edge
);
83 extern void predict_edge_def (edge
, enum br_predictor
, enum prediction
);
84 extern void invert_br_probabilities (rtx
);
85 extern void guess_outgoing_edge_probabilities (basic_block
);
86 extern void tree_guess_outgoing_edge_probabilities (basic_block
);
87 extern void tree_estimate_probability (bool);
88 extern void handle_missing_profiles (void);
89 extern bool counts_to_freqs (void);
90 extern bool expensive_function_p (int);
91 extern void estimate_bb_frequencies (bool);
92 extern void compute_function_frequency (void);
93 extern tree
build_predict_expr (enum br_predictor
, enum prediction
);
94 extern const char *predictor_name (enum br_predictor
);
95 extern void rebuild_frequencies (void);
96 extern void report_predictor_hitrates (void);
97 extern void force_edge_cold (edge
, bool);
99 #endif /* GCC_PREDICT_H */