public inbox for
 help / color / mirror / Atom feed
* [PATCH] Improve vector_vector_composition_type
@ 2023-06-23  6:44 Richard Biener
  0 siblings, 0 replies; only message in thread
From: Richard Biener @ 2023-06-23  6:44 UTC (permalink / raw)
  To: gcc-patches

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.

Bootstrapped and tested on x86_64-unknown-linux-gnu, pushed.

	* (vector_vector_composition_type):
	Handle composition of a vector from a number of elements that
	happens to match its number of lanes.
 gcc/ | 8 ++++++++
 1 file changed, 8 insertions(+)

diff --git a/gcc/ b/gcc/
index ae24f3e66e6..9e046ced7c6 100644
--- a/gcc/
+++ b/gcc/
@@ -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))

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-06-23  6:44 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-06-23  6:44 [PATCH] Improve vector_vector_composition_type Richard Biener

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).