diff options
author | Richard Biener <rguenther@suse.de> | 2020-09-29 12:01:26 +0200 |
---|---|---|
committer | Richard Biener <rguenther@suse.de> | 2020-09-29 14:44:04 +0200 |
commit | b1570930df659ff3ea6691f9ba8b84c8a189d85d (patch) | |
tree | 8fdde8bfcb4742eadcd2acd95305572e86bbcc65 /gcc | |
parent | d68f4d2ecb8ed6781e4e535d2abc498b1674d68a (diff) | |
download | gcc-b1570930df659ff3ea6691f9ba8b84c8a189d85d.zip gcc-b1570930df659ff3ea6691f9ba8b84c8a189d85d.tar.gz gcc-b1570930df659ff3ea6691f9ba8b84c8a189d85d.tar.bz2 |
move permute optimization to optimize-slp
This moves optimizing permutes of SLP reductions to vect_optimize_slp,
eliding the global slp_loads array.
2020-09-29 Richard Biener <rguenther@suse.de>
* tree-vect-slp.c (vect_analyze_slp): Move SLP reduction
re-arrangement and SLP graph load gathering...
(vect_optimize_slp): ... here.
* tree-vectorizer.h (vec_info::slp_loads): Remove.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/tree-vect-slp.c | 19 | ||||
-rw-r--r-- | gcc/tree-vectorizer.h | 1 |
2 files changed, 10 insertions, 10 deletions
diff --git a/gcc/tree-vect-slp.c b/gcc/tree-vect-slp.c index c44fd39..8de2480 100644 --- a/gcc/tree-vect-slp.c +++ b/gcc/tree-vect-slp.c @@ -2486,8 +2486,15 @@ vect_analyze_slp (vec_info *vinfo, unsigned max_tree_size) vect_free_slp_tree ((*it).second); delete bst_map; + return opt_result::success (); +} + +void +vect_optimize_slp (vec_info *vinfo) +{ /* Optimize permutations in SLP reductions. */ slp_instance instance; + unsigned i; FOR_EACH_VEC_ELT (vinfo->slp_instances, i, instance) { slp_tree node = SLP_INSTANCE_TREE (instance); @@ -2500,20 +2507,14 @@ vect_analyze_slp (vec_info *vinfo, unsigned max_tree_size) } /* Gather all loads in the SLP graph. */ + auto_vec<slp_tree> slp_loads; hash_set<slp_tree> visited; FOR_EACH_VEC_ELT (vinfo->slp_instances, i, instance) - vect_gather_slp_loads (vinfo->slp_loads, SLP_INSTANCE_TREE (instance), + vect_gather_slp_loads (slp_loads, SLP_INSTANCE_TREE (instance), visited); - return opt_result::success (); -} - -void -vect_optimize_slp (vec_info *vinfo) -{ slp_tree node; - unsigned i; - FOR_EACH_VEC_ELT (vinfo->slp_loads, i, node) + FOR_EACH_VEC_ELT (slp_loads, i, node) { if (!SLP_TREE_LOAD_PERMUTATION (node).exists ()) continue; diff --git a/gcc/tree-vectorizer.h b/gcc/tree-vectorizer.h index b7fa6bc..e62f1cc 100644 --- a/gcc/tree-vectorizer.h +++ b/gcc/tree-vectorizer.h @@ -359,7 +359,6 @@ public: /* The SLP graph. */ auto_vec<slp_instance> slp_instances; - auto_vec<slp_tree> slp_loads; /* Maps base addresses to an innermost_loop_behavior that gives the maximum known alignment for that base. */ |