diff options
author | Ira Rosen <ira.rosen@linaro.org> | 2011-09-25 12:33:03 +0000 |
---|---|---|
committer | Ira Rosen <irar@gcc.gnu.org> | 2011-09-25 12:33:03 +0000 |
commit | 8e19f5a1b3c48e05595cba58223fcb2ae1504599 (patch) | |
tree | 5e6b24cfe0fb459242ac91d070e83079a6dc651c /gcc/tree-vect-slp.c | |
parent | 13ec1ccaaa69f1b12be42b3bb91f4223eea7e4df (diff) | |
download | gcc-8e19f5a1b3c48e05595cba58223fcb2ae1504599.tar.gz |
tree-vect-slp.c (vect_slp_analyze_bb_1): Split out core part of vect_analyze_bb here.
* tree-vect-slp.c (vect_slp_analyze_bb_1): Split out core part
of vect_analyze_bb here.
(vect_analyze_bb): Loop over vector sizes calling
vect_analyze_bb_1.
From-SVN: r179164
Diffstat (limited to 'gcc/tree-vect-slp.c')
-rw-r--r-- | gcc/tree-vect-slp.c | 85 |
1 files changed, 58 insertions, 27 deletions
diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c index 9171ba991b1..5dc5cf694b2 100644 --- a/gcc/tree-vect-slp.c +++ b/gcc/tree-vect-slp.c @@ -1694,42 +1694,18 @@ vect_bb_vectorization_profitable_p (bb_vec_info bb_vinfo) /* Check if the basic block can be vectorized. */ -bb_vec_info -vect_slp_analyze_bb (basic_block bb) +static bb_vec_info +vect_slp_analyze_bb_1 (basic_block bb) { bb_vec_info bb_vinfo; VEC (ddr_p, heap) *ddrs; VEC (slp_instance, heap) *slp_instances; slp_instance instance; - int i, insns = 0; - gimple_stmt_iterator gsi; + int i; int min_vf = 2; int max_vf = MAX_VECTORIZATION_FACTOR; bool data_dependence_in_bb = false; - current_vector_size = 0; - - if (vect_print_dump_info (REPORT_DETAILS)) - fprintf (vect_dump, "===vect_slp_analyze_bb===\n"); - - for (gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi)) - { - gimple stmt = gsi_stmt (gsi); - if (!is_gimple_debug (stmt) - && !gimple_nop_p (stmt) - && gimple_code (stmt) != GIMPLE_LABEL) - insns++; - } - - if (insns > PARAM_VALUE (PARAM_SLP_MAX_INSNS_IN_BB)) - { - if (vect_print_dump_info (REPORT_UNVECTORIZED_LOCATIONS)) - fprintf (vect_dump, "not vectorized: too many instructions in basic " - "block.\n"); - - return NULL; - } - bb_vinfo = new_bb_vec_info (bb); if (!bb_vinfo) return NULL; @@ -1849,6 +1825,61 @@ vect_slp_analyze_bb (basic_block bb) } +bb_vec_info +vect_slp_analyze_bb (basic_block bb) +{ + bb_vec_info bb_vinfo; + int insns = 0; + gimple_stmt_iterator gsi; + unsigned int vector_sizes; + + if (vect_print_dump_info (REPORT_DETAILS)) + fprintf (vect_dump, "===vect_slp_analyze_bb===\n"); + + for (gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi)) + { + gimple stmt = gsi_stmt (gsi); + if (!is_gimple_debug (stmt) + && !gimple_nop_p (stmt) + && gimple_code (stmt) != GIMPLE_LABEL) + insns++; + } + + if (insns > PARAM_VALUE (PARAM_SLP_MAX_INSNS_IN_BB)) + { + if (vect_print_dump_info (REPORT_UNVECTORIZED_LOCATIONS)) + fprintf (vect_dump, "not vectorized: too many instructions in basic " + "block.\n"); + + return NULL; + } + + /* Autodetect first vector size we try. */ + current_vector_size = 0; + vector_sizes = targetm.vectorize.autovectorize_vector_sizes (); + + while (1) + { + bb_vinfo = vect_slp_analyze_bb_1 (bb); + if (bb_vinfo) + return bb_vinfo; + + destroy_bb_vec_info (bb_vinfo); + + vector_sizes &= ~current_vector_size; + if (vector_sizes == 0 + || current_vector_size == 0) + return NULL; + + /* Try the next biggest vector size. */ + current_vector_size = 1 << floor_log2 (vector_sizes); + if (vect_print_dump_info (REPORT_DETAILS)) + fprintf (vect_dump, "***** Re-trying analysis with " + "vector size %d\n", current_vector_size); + } +} + + /* SLP costs are calculated according to SLP instance unrolling factor (i.e., the number of created vector stmts depends on the unrolling factor). However, the actual number of vector stmts for every SLP node depends on |