re PR rtl-optimization/23490 (Long compile time for array initializer with inlined constructor)

PR rtl-optimization/23490
	* doc/invoke.texi (max-predicted-iterations, max-cse-insns,
	max-flow-memory-location): Document.
	* flow.c: Include params.h
	(MAX_MEM_SET_LIST_LEN): Kill.
	(add_to_mem_set_list): Use new param.
	* cse.c (cse_basic_block): Replace 1000 by new param.
	* params.def (PARAM_MAX_PREDICTED_ITERATIONS, PARAM_MAX_CSE_INSNS,
	PARAM_MAX_FLOW_MEMORY_LOCATIONS): New.
	* predict.c (predict_loops): Use new param.
	* predict.def (MAX_PRED_LOOP_ITERATIONS): Remove.

From-SVN: r106520
This commit is contained in:
Jan Hubicka 2005-11-05 01:55:23 +01:00 committed by Jan Hubicka
parent 50fe876da0
commit 95b9a3a55c
7 changed files with 60 additions and 26 deletions

View File

@ -1,5 +1,17 @@
2005-11-05 Jan Hubicka <jh@suse.cz> 2005-11-05 Jan Hubicka <jh@suse.cz>
PR rtl-optimization/23490
* doc/invoke.texi (max-predicted-iterations, max-cse-insns,
max-flow-memory-location): Document.
* flow.c: Include params.h
(MAX_MEM_SET_LIST_LEN): Kill.
(add_to_mem_set_list): Use new param.
* cse.c (cse_basic_block): Replace 1000 by new param.
* params.def (PARAM_MAX_PREDICTED_ITERATIONS, PARAM_MAX_CSE_INSNS,
PARAM_MAX_FLOW_MEMORY_LOCATIONS): New.
* predict.c (predict_loops): Use new param.
* predict.def (MAX_PRED_LOOP_ITERATIONS): Remove.
* ipa-inline.c (cgraph_decide_inlining_of_small_function, * ipa-inline.c (cgraph_decide_inlining_of_small_function,
cgraph_decide_inlining, cgraph_decide_inlining_incrementally): cgraph_decide_inlining, cgraph_decide_inlining_incrementally):
Do not hold memory returned by cgraph_node_name across other call. Do not hold memory returned by cgraph_node_name across other call.

View File

@ -6890,7 +6890,7 @@ cse_basic_block (rtx from, rtx to, struct branch_path *next_branch)
??? This is a real kludge and needs to be done some other way. ??? This is a real kludge and needs to be done some other way.
Perhaps for 2.9. */ Perhaps for 2.9. */
if (code != NOTE && num_insns++ > 1000) if (code != NOTE && num_insns++ > PARAM_VALUE (PARAM_MAX_CSE_INSNS))
{ {
flush_hash_table (); flush_hash_table ();
num_insns = 0; num_insns = 0;

View File

@ -5935,6 +5935,13 @@ given basic block needs to have to be considered hot.
Select fraction of the maximal frequency of executions of basic block in Select fraction of the maximal frequency of executions of basic block in
function given basic block needs to have to be considered hot function given basic block needs to have to be considered hot
@item max-predicted-iterations
The maximum number of loop iterations we predict statically. This is useful
in cases where function contain single loop with known bound and other loop
with unknown. We predict the known number of iterations correctly, while
the unknown nummber of iterations average to roughly 10. This means that the
loop without bounds would appear artifically cold relative to the other one.
@item tracer-dynamic-coverage @item tracer-dynamic-coverage
@itemx tracer-dynamic-coverage-feedback @itemx tracer-dynamic-coverage-feedback
@ -5972,6 +5979,9 @@ order to make tracer effective.
Maximum number of basic blocks on path that cse considers. The default is 10. Maximum number of basic blocks on path that cse considers. The default is 10.
@item max-cse-insns
The maximum instructions CSE process before flushing. The default is 1000.
@item global-var-threshold @item global-var-threshold
Counts the number of function calls (@var{n}) and the number of Counts the number of function calls (@var{n}) and the number of
@ -6033,6 +6043,10 @@ The maximum number of memory locations cselib should take into acount.
Increasing values mean more aggressive optimization, making the compile time Increasing values mean more aggressive optimization, making the compile time
increase with probably slightly better performance. The default value is 500. increase with probably slightly better performance. The default value is 500.
@item max-flow-memory-location
Similar as @option{max-cselib-memory-location} but for dataflow liveness.
The default value is 100.
@item reorder-blocks-duplicate @item reorder-blocks-duplicate
@itemx reorder-blocks-duplicate-feedback @itemx reorder-blocks-duplicate-feedback

View File

@ -141,6 +141,7 @@ Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
#include "obstack.h" #include "obstack.h"
#include "splay-tree.h" #include "splay-tree.h"
#include "tree-pass.h" #include "tree-pass.h"
#include "params.h"
#ifndef HAVE_epilogue #ifndef HAVE_epilogue
#define HAVE_epilogue 0 #define HAVE_epilogue 0
@ -283,10 +284,6 @@ static int ndead;
static int *reg_deaths; static int *reg_deaths;
/* Maximum length of pbi->mem_set_list before we start dropping
new elements on the floor. */
#define MAX_MEM_SET_LIST_LEN 100
/* Forward declarations */ /* Forward declarations */
static int verify_wide_reg_1 (rtx *, void *); static int verify_wide_reg_1 (rtx *, void *);
static void verify_wide_reg (int, basic_block); static void verify_wide_reg (int, basic_block);
@ -630,7 +627,7 @@ update_life_info (sbitmap blocks, enum update_life_extent extent,
/* We repeat regardless of what cleanup_cfg says. If there were /* We repeat regardless of what cleanup_cfg says. If there were
instructions deleted above, that might have been only a instructions deleted above, that might have been only a
partial improvement (see MAX_MEM_SET_LIST_LEN usage). partial improvement (see PARAM_MAX_FLOW_MEMORY_LOCATIONS usage).
Further improvement may be possible. */ Further improvement may be possible. */
cleanup_cfg (CLEANUP_EXPENSIVE); cleanup_cfg (CLEANUP_EXPENSIVE);
@ -2515,7 +2512,7 @@ add_to_mem_set_list (struct propagate_block_info *pbi, rtx mem)
} }
} }
if (pbi->mem_set_list_len < MAX_MEM_SET_LIST_LEN) if (pbi->mem_set_list_len < PARAM_VALUE (PARAM_MAX_FLOW_MEMORY_LOCATIONS))
{ {
#ifdef AUTO_INC_DEC #ifdef AUTO_INC_DEC
/* Store a copy of mem, otherwise the address may be /* Store a copy of mem, otherwise the address may be

View File

@ -309,6 +309,22 @@ DEFPARAM(HOT_BB_FREQUENCY_FRACTION,
"hot-bb-frequency-fraction", "hot-bb-frequency-fraction",
"Select fraction of the maximal frequency of executions of basic block in function given basic block needs to have to be considered hot", "Select fraction of the maximal frequency of executions of basic block in function given basic block needs to have to be considered hot",
1000, 0, 0) 1000, 0, 0)
/* For guessed profiles, the loops having unknown number of iterations
are predicted to iterate relatively few (10) times at average.
For functions containing one loop with large known number of iterations
and other loops having unbounded loops we would end up predicting all
the other loops cold that is not usually the case. So we need to artifically
flatten the profile.
We need to cut the maximal predicted iterations to large enought iterations
so the loop appears important, but safely within HOT_BB_COUNT_FRACTION
range. */
DEFPARAM(PARAM_MAX_PREDICTED_ITERATIONS,
"max-predicted-iterations",
"The maximum number of loop iterations we predict statically",
100, 0, 0)
DEFPARAM(TRACER_DYNAMIC_COVERAGE_FEEDBACK, DEFPARAM(TRACER_DYNAMIC_COVERAGE_FEEDBACK,
"tracer-dynamic-coverage-feedback", "tracer-dynamic-coverage-feedback",
"The percentage of function, weighted by execution frequency, that must be covered by trace formation. Used when profile feedback is available", "The percentage of function, weighted by execution frequency, that must be covered by trace formation. Used when profile feedback is available",
@ -363,6 +379,10 @@ DEFPARAM(PARAM_MAX_CSE_PATH_LENGTH,
"max-cse-path-length", "max-cse-path-length",
"The maximum length of path considered in cse", "The maximum length of path considered in cse",
10, 0, 0) 10, 0, 0)
DEFPARAM(PARAM_MAX_CSE_INSNS,
"max-flow-memory-locations",
"The maximum instructions CSE process before flushing",
1000, 0, 0)
/* The cost of expression in loop invariant motion that is considered /* The cost of expression in loop invariant motion that is considered
expensive. */ expensive. */
@ -417,6 +437,10 @@ DEFPARAM(PARAM_MAX_CSELIB_MEMORY_LOCATIONS,
"max-cselib-memory-locations", "max-cselib-memory-locations",
"The maximum memory locations recorded by cselib", "The maximum memory locations recorded by cselib",
500, 0, 0) 500, 0, 0)
DEFPARAM(PARAM_MAX_FLOW_MEMORY_LOCATIONS,
"max-flow-memory-locations",
"The maximum memory locations recorded by flow",
100, 0, 0)
#ifdef ENABLE_GC_ALWAYS_COLLECT #ifdef ENABLE_GC_ALWAYS_COLLECT
# define GGC_MIN_EXPAND_DEFAULT 0 # define GGC_MIN_EXPAND_DEFAULT 0

View File

@ -624,8 +624,9 @@ predict_loops (struct loops *loops_info, bool rtlsimpleloops)
niter = desc.niter + 1; niter = desc.niter + 1;
if (niter == 0) /* We might overflow here. */ if (niter == 0) /* We might overflow here. */
niter = desc.niter; niter = desc.niter;
if (niter > MAX_PRED_LOOP_ITERATIONS) if (niter
niter = MAX_PRED_LOOP_ITERATIONS; > (unsigned int) PARAM_VALUE (PARAM_MAX_PREDICTED_ITERATIONS))
niter = PARAM_VALUE (PARAM_MAX_PREDICTED_ITERATIONS);
prob = (REG_BR_PROB_BASE prob = (REG_BR_PROB_BASE
- (REG_BR_PROB_BASE + niter /2) / niter); - (REG_BR_PROB_BASE + niter /2) / niter);
@ -653,19 +654,17 @@ predict_loops (struct loops *loops_info, bool rtlsimpleloops)
if (TREE_CODE (niter) == INTEGER_CST) if (TREE_CODE (niter) == INTEGER_CST)
{ {
int probability; int probability;
int max = PARAM_VALUE (PARAM_MAX_PREDICTED_ITERATIONS);
if (host_integerp (niter, 1) if (host_integerp (niter, 1)
&& tree_int_cst_lt (niter, && tree_int_cst_lt (niter,
build_int_cstu (NULL_TREE, build_int_cstu (NULL_TREE, max - 1)))
MAX_PRED_LOOP_ITERATIONS - 1)))
{ {
HOST_WIDE_INT nitercst = tree_low_cst (niter, 1) + 1; HOST_WIDE_INT nitercst = tree_low_cst (niter, 1) + 1;
probability = ((REG_BR_PROB_BASE + nitercst / 2) probability = ((REG_BR_PROB_BASE + nitercst / 2)
/ nitercst); / nitercst);
} }
else else
probability = ((REG_BR_PROB_BASE probability = ((REG_BR_PROB_BASE + max / 2) / max);
+ MAX_PRED_LOOP_ITERATIONS / 2)
/ MAX_PRED_LOOP_ITERATIONS);
predict_edge (exits[j], PRED_LOOP_ITERATIONS, probability); predict_edge (exits[j], PRED_LOOP_ITERATIONS, probability);
} }

View File

@ -58,18 +58,6 @@ DEF_PREDICTOR (PRED_UNCONDITIONAL, "unconditional jump", PROB_ALWAYS,
DEF_PREDICTOR (PRED_LOOP_ITERATIONS, "loop iterations", PROB_ALWAYS, DEF_PREDICTOR (PRED_LOOP_ITERATIONS, "loop iterations", PROB_ALWAYS,
PRED_FLAG_FIRST_MATCH) PRED_FLAG_FIRST_MATCH)
/* For guessed profiles, the loops having unknown number of iterations
are predicted to iterate relatively few (10) times at average.
For functions containing one loop with large known number of iterations
and other loops having unbounded loops we would end up predicting all
the other loops cold that is not usually the case. So we need to artifically
flatten the profile.
We need to cut the maximal predicted iterations to large enought iterations
so the loop appears important, but safely within HOT_BB_COUNT_FRACTION
range. */
#define MAX_PRED_LOOP_ITERATIONS 100
/* Hints dropped by user via __builtin_expect feature. */ /* Hints dropped by user via __builtin_expect feature. */
DEF_PREDICTOR (PRED_BUILTIN_EXPECT, "__builtin_expect", PROB_VERY_LIKELY, DEF_PREDICTOR (PRED_BUILTIN_EXPECT, "__builtin_expect", PROB_VERY_LIKELY,
PRED_FLAG_FIRST_MATCH) PRED_FLAG_FIRST_MATCH)