aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vect-stmts.cc
diff options
context:
space:
mode:
authorRichard Biener <rguenther@suse.de>2023-06-22 15:14:51 +0200
committerRichard Biener <rguenther@suse.de>2023-06-23 08:44:25 +0200
commit1742ea94aaa758a2b0c40360f89e27770bd8ffeb (patch)
treecd8a3d7db9c5b7df9f6b457257b2491c3922f954 /gcc/tree-vect-stmts.cc
parent270742ceb5141db498ef63373512ed071923b940 (diff)
downloadgcc-1742ea94aaa758a2b0c40360f89e27770bd8ffeb.zip
gcc-1742ea94aaa758a2b0c40360f89e27770bd8ffeb.tar.gz
gcc-1742ea94aaa758a2b0c40360f89e27770bd8ffeb.tar.bz2
Improve vector_vector_composition_type
We sometimes get to ask to decompose, say V2DFmode into two halves. Currently this results in composing it from two DImode pieces instead of the obvious two DFmode pieces. The following adjusts vector_vector_composition_type for this trivial case and avoids a VIEW_CONVERT_EXPR in the initial code generation. * tree-vect-stmts.cc (vector_vector_composition_type): Handle composition of a vector from a number of elements that happens to match its number of lanes.
Diffstat (limited to 'gcc/tree-vect-stmts.cc')
-rw-r--r--gcc/tree-vect-stmts.cc8
1 files changed, 8 insertions, 0 deletions
diff --git a/gcc/tree-vect-stmts.cc b/gcc/tree-vect-stmts.cc
index ae24f3e..9e046ce 100644
--- a/gcc/tree-vect-stmts.cc
+++ b/gcc/tree-vect-stmts.cc
@@ -2143,6 +2143,14 @@ vector_vector_composition_type (tree vtype, poly_uint64 nelts, tree *ptype)
if (!VECTOR_MODE_P (vmode))
return NULL_TREE;
+ /* When we are asked to compose the vector from its components let
+ that happen directly. */
+ if (known_eq (TYPE_VECTOR_SUBPARTS (vtype), nelts))
+ {
+ *ptype = TREE_TYPE (vtype);
+ return vtype;
+ }
+
poly_uint64 vbsize = GET_MODE_BITSIZE (vmode);
unsigned int pbsize;
if (constant_multiple_p (vbsize, nelts, &pbsize))