aboutsummaryrefslogtreecommitdiff
path: root/gcc/combine.c
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2020-09-08 14:49:59 +0200
committerRichard Biener <rguenther@suse.de>2020-09-10 11:18:18 +0200
commit47ddf4c7b1d4471cb9534f27844ab5e4279c2168 (patch)
tree5983e9d8c24326c178aa7f721b107e4651fa1628 /gcc/combine.c
parent484af18ee1c63eb8d212563e40aa765da5be7f82 (diff)
downloadgcc-47ddf4c7b1d4471cb9534f27844ab5e4279c2168.zip
gcc-47ddf4c7b1d4471cb9534f27844ab5e4279c2168.tar.gz
gcc-47ddf4c7b1d4471cb9534f27844ab5e4279c2168.tar.bz2
tree-optimization/96043 - BB vectorization costing improvement
This makes the BB vectorizer cost independent SLP subgraphs separately. While on pristine trunk and for x86_64 I failed to distill a testcase where the vectorizer would think _any_ basic-block vectorization opportunity is not profitable I do have pending work that would make the cost savings of a profitable opportunity make another independently not profitable opportunity vectorized. 2020-09-08 Richard Biener <rguenther@suse.de> PR tree-optimization/96043 * tree-vectorizer.h (_slp_instance::cost_vec): New. (_slp_instance::subgraph_entries): Likewise. (BB_VINFO_TARGET_COST_DATA): Remove. * tree-vect-slp.c (vect_free_slp_instance): Free cost_vec and subgraph_entries. (vect_analyze_slp_instance): Initialize them. (vect_slp_analyze_operations): Defer passing costs to the target, instead record them in the SLP graph entry. (get_ultimate_leader): New helper for graph partitioning. (vect_bb_partition_graph_r): Likewise. (vect_bb_partition_graph): New function to partition the SLP graph into independently costable parts. (vect_bb_vectorization_profitable_p): Adjust to work on a subgraph. (vect_bb_vectorization_profitable_p): New wrapper, discarding non-profitable vectorization of subgraphs. (vect_slp_analyze_bb_1): Call vect_bb_partition_graph before costing. * gcc.dg/vect/costmodel/x86_64/costmodel-pr69297.c: Adjust.
Diffstat (limited to 'gcc/combine.c')
0 files changed, 0 insertions, 0 deletions