aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTamar Christina <tamar.christina@arm.com>2024-10-14 13:58:09 +0100
committerTamar Christina <tamar.christina@arm.com>2024-10-14 13:58:09 +0100
commit306834b7f74ab61160f205e04f5bf35b71f9ec52 (patch)
tree5b1ea48a8c25636f78b0389039a01215664eee4c
parent1c507a02f29c6ca735f40f4b16b341ce9d5aa1b1 (diff)
downloadgcc-306834b7f74ab61160f205e04f5bf35b71f9ec52.zip
gcc-306834b7f74ab61160f205e04f5bf35b71f9ec52.tar.gz
gcc-306834b7f74ab61160f205e04f5bf35b71f9ec52.tar.bz2
AArch64: rename the SVE2 psel intrinsics to psel_lane [PR116371]
The psel intrinsics. similar to the pext, should be name psel_lane. This corrects the naming. gcc/ChangeLog: PR target/116371 * config/aarch64/aarch64-sve-builtins-sve2.cc (class svpsel_impl): Renamed to ... (class svpsel_lane_impl): ... This and adjust initialization. * config/aarch64/aarch64-sve-builtins-sve2.def (svpsel): Renamed to ... (svpsel_lane): ... This. * config/aarch64/aarch64-sve-builtins-sve2.h (svpsel): Renamed to svpsel_lane. gcc/testsuite/ChangeLog: PR target/116371 * gcc.target/aarch64/sme2/acle-asm/psel_b16.c, gcc.target/aarch64/sme2/acle-asm/psel_b32.c, gcc.target/aarch64/sme2/acle-asm/psel_b64.c, gcc.target/aarch64/sme2/acle-asm/psel_b8.c, gcc.target/aarch64/sme2/acle-asm/psel_c16.c, gcc.target/aarch64/sme2/acle-asm/psel_c32.c, gcc.target/aarch64/sme2/acle-asm/psel_c64.c, gcc.target/aarch64/sme2/acle-asm/psel_c8.c: Renamed to.... * gcc.target/aarch64/sme2/acle-asm/psel_lane_b16.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_b32.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_b64.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_b8.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_c16.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_c32.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_c64.c, gcc.target/aarch64/sme2/acle-asm/psel_lane_c8.c: ... These.
-rw-r--r--gcc/config/aarch64/aarch64-sve-builtins-sve2.cc4
-rw-r--r--gcc/config/aarch64/aarch64-sve-builtins-sve2.def2
-rw-r--r--gcc/config/aarch64/aarch64-sve-builtins-sve2.h2
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b16.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b32.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b64.c80
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b8.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c16.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c32.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c64.c80
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c8.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b16.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b32.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b64.c80
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b8.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c16.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c32.c89
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c64.c80
-rw-r--r--gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c8.c89
19 files changed, 698 insertions, 698 deletions
diff --git a/gcc/config/aarch64/aarch64-sve-builtins-sve2.cc b/gcc/config/aarch64/aarch64-sve-builtins-sve2.cc
index 146a545..6a20a61 100644
--- a/gcc/config/aarch64/aarch64-sve-builtins-sve2.cc
+++ b/gcc/config/aarch64/aarch64-sve-builtins-sve2.cc
@@ -234,7 +234,7 @@ public:
}
};
-class svpsel_impl : public function_base
+class svpsel_lane_impl : public function_base
{
public:
rtx
@@ -625,7 +625,7 @@ FUNCTION (svpmullb, unspec_based_function, (-1, UNSPEC_PMULLB, -1))
FUNCTION (svpmullb_pair, unspec_based_function, (-1, UNSPEC_PMULLB_PAIR, -1))
FUNCTION (svpmullt, unspec_based_function, (-1, UNSPEC_PMULLT, -1))
FUNCTION (svpmullt_pair, unspec_based_function, (-1, UNSPEC_PMULLT_PAIR, -1))
-FUNCTION (svpsel, svpsel_impl,)
+FUNCTION (svpsel_lane, svpsel_lane_impl,)
FUNCTION (svqabs, rtx_code_function, (SS_ABS, UNKNOWN, UNKNOWN))
FUNCTION (svqcadd, svqcadd_impl,)
FUNCTION (svqcvt, integer_conversion, (UNSPEC_SQCVT, UNSPEC_SQCVTU,
diff --git a/gcc/config/aarch64/aarch64-sve-builtins-sve2.def b/gcc/config/aarch64/aarch64-sve-builtins-sve2.def
index 4543402..318dfff 100644
--- a/gcc/config/aarch64/aarch64-sve-builtins-sve2.def
+++ b/gcc/config/aarch64/aarch64-sve-builtins-sve2.def
@@ -235,7 +235,7 @@ DEF_SVE_FUNCTION (svsm4ekey, binary, s_unsigned, none)
| AARCH64_FL_SME \
| AARCH64_FL_SM_ON)
DEF_SVE_FUNCTION (svclamp, clamp, all_integer, none)
-DEF_SVE_FUNCTION (svpsel, select_pred, all_pred_count, none)
+DEF_SVE_FUNCTION (svpsel_lane, select_pred, all_pred_count, none)
DEF_SVE_FUNCTION (svrevd, unary, all_data, mxz)
#undef REQUIRED_EXTENSIONS
diff --git a/gcc/config/aarch64/aarch64-sve-builtins-sve2.h b/gcc/config/aarch64/aarch64-sve-builtins-sve2.h
index 2ac6ede..013a9df 100644
--- a/gcc/config/aarch64/aarch64-sve-builtins-sve2.h
+++ b/gcc/config/aarch64/aarch64-sve-builtins-sve2.h
@@ -106,7 +106,7 @@ namespace aarch64_sve
extern const function_base *const svpmullb_pair;
extern const function_base *const svpmullt;
extern const function_base *const svpmullt_pair;
- extern const function_base *const svpsel;
+ extern const function_base *const svpsel_lane;
extern const function_base *const svqabs;
extern const function_base *const svqcadd;
extern const function_base *const svqcvt;
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b16.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b16.c
deleted file mode 100644
index 5df2aa0..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b16.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svbool_t,
- p0 = svpsel_b16 (p2, p7, 0),
- p0 = svpsel_b16 (p2, p7, 0))
-
-/*
-** psel_p2_p7_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p7, p8\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p7_p8_w11, svbool_t,
- p2 = svpsel_b16 (p7, p8, w11),
- p2 = svpsel_b16 (p7, p8, w11))
-
-/*
-** psel_p7_p8_p13_w12:
-** psel p7, p8, p13\.h\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p7_p8_p13_w12, svbool_t,
- p7 = svpsel_b16 (p8, p13, w12),
- p7 = svpsel_b16 (p8, p13, w12))
-
-/*
-** psel_p8_p13_p15_w15:
-** psel p8, p13, p15\.h\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p8_p13_p15_w15, svbool_t,
- p8 = svpsel_b16 (p13, p15, w15),
- p8 = svpsel_b16 (p13, p15, w15))
-
-/*
-** psel_p13_p15_p0_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p15, p0\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p15_p0_w16, svbool_t,
- p13 = svpsel_b16 (p15, p0, w16),
- p13 = svpsel_b16 (p15, p0, w16))
-
-/*
-** psel_p15_p13_p8_w12p1:
-** psel p15, p13, p8\.h\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p13_p8_w12p1, svbool_t,
- p15 = svpsel_b16 (p13, p8, w12 + 1),
- p15 = svpsel_b16 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p8_p7_w12p7:
-** psel p13, p8, p7\.h\[w12, 7\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p8_p7_w12p7, svbool_t,
- p13 = svpsel_b16 (p8, p7, w12 + 7),
- p13 = svpsel_b16 (p8, p7, w12 + 7))
-
-/*
-** psel_p0_p0_p0_w12p8:
-** add (w[0-9]+), w12, #?8
-** psel p0, p0, p0\.h\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p0_w12p8, svbool_t,
- p0 = svpsel_b16 (p0, p0, w12 + 8),
- p0 = svpsel_b16 (p0, p0, w12 + 8))
-
-/*
-** psel_p15_p15_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p15, p15, p15\.h\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p15_p15_w12m1, svbool_t,
- p15 = svpsel_b16 (p15, p15, w12 - 1),
- p15 = svpsel_b16 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b32.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b32.c
deleted file mode 100644
index 8489dca..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b32.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svbool_t,
- p0 = svpsel_b32 (p2, p7, 0),
- p0 = svpsel_b32 (p2, p7, 0))
-
-/*
-** psel_p2_p7_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p7, p8\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p7_p8_w11, svbool_t,
- p2 = svpsel_b32 (p7, p8, w11),
- p2 = svpsel_b32 (p7, p8, w11))
-
-/*
-** psel_p7_p8_p13_w12:
-** psel p7, p8, p13\.s\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p7_p8_p13_w12, svbool_t,
- p7 = svpsel_b32 (p8, p13, w12),
- p7 = svpsel_b32 (p8, p13, w12))
-
-/*
-** psel_p8_p13_p15_w15:
-** psel p8, p13, p15\.s\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p8_p13_p15_w15, svbool_t,
- p8 = svpsel_b32 (p13, p15, w15),
- p8 = svpsel_b32 (p13, p15, w15))
-
-/*
-** psel_p13_p15_p0_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p15, p0\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p15_p0_w16, svbool_t,
- p13 = svpsel_b32 (p15, p0, w16),
- p13 = svpsel_b32 (p15, p0, w16))
-
-/*
-** psel_p15_p13_p8_w12p1:
-** psel p15, p13, p8\.s\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p13_p8_w12p1, svbool_t,
- p15 = svpsel_b32 (p13, p8, w12 + 1),
- p15 = svpsel_b32 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p8_p7_w12p3:
-** psel p13, p8, p7\.s\[w12, 3\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p8_p7_w12p3, svbool_t,
- p13 = svpsel_b32 (p8, p7, w12 + 3),
- p13 = svpsel_b32 (p8, p7, w12 + 3))
-
-/*
-** psel_p0_p0_p0_w12p4:
-** add (w[0-9]+), w12, #?4
-** psel p0, p0, p0\.s\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p0_w12p4, svbool_t,
- p0 = svpsel_b32 (p0, p0, w12 + 4),
- p0 = svpsel_b32 (p0, p0, w12 + 4))
-
-/*
-** psel_p15_p15_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p15, p15, p15\.s\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p15_p15_w12m1, svbool_t,
- p15 = svpsel_b32 (p15, p15, w12 - 1),
- p15 = svpsel_b32 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b64.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b64.c
deleted file mode 100644
index 5d2d8b4..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b64.c
+++ /dev/null
@@ -1,80 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svbool_t,
- p0 = svpsel_b64 (p2, p7, 0),
- p0 = svpsel_b64 (p2, p7, 0))
-
-/*
-** psel_p2_p7_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p7, p8\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p7_p8_w11, svbool_t,
- p2 = svpsel_b64 (p7, p8, w11),
- p2 = svpsel_b64 (p7, p8, w11))
-
-/*
-** psel_p7_p8_p13_w12:
-** psel p7, p8, p13\.d\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p7_p8_p13_w12, svbool_t,
- p7 = svpsel_b64 (p8, p13, w12),
- p7 = svpsel_b64 (p8, p13, w12))
-
-/*
-** psel_p8_p13_p15_w15:
-** psel p8, p13, p15\.d\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p8_p13_p15_w15, svbool_t,
- p8 = svpsel_b64 (p13, p15, w15),
- p8 = svpsel_b64 (p13, p15, w15))
-
-/*
-** psel_p13_p15_p0_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p15, p0\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p15_p0_w16, svbool_t,
- p13 = svpsel_b64 (p15, p0, w16),
- p13 = svpsel_b64 (p15, p0, w16))
-
-/*
-** psel_p15_p13_p8_w12p1:
-** psel p15, p13, p8\.d\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p13_p8_w12p1, svbool_t,
- p15 = svpsel_b64 (p13, p8, w12 + 1),
- p15 = svpsel_b64 (p13, p8, w12 + 1))
-
-/*
-** psel_p0_p0_p0_w12p2:
-** add (w[0-9]+), w12, #?2
-** psel p0, p0, p0\.d\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p0_w12p2, svbool_t,
- p0 = svpsel_b64 (p0, p0, w12 + 2),
- p0 = svpsel_b64 (p0, p0, w12 + 2))
-
-/*
-** psel_p15_p15_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p15, p15, p15\.d\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p15_p15_w12m1, svbool_t,
- p15 = svpsel_b64 (p15, p15, w12 - 1),
- p15 = svpsel_b64 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b8.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b8.c
deleted file mode 100644
index 4387358..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_b8.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svbool_t,
- p0 = svpsel_b8 (p2, p7, 0),
- p0 = svpsel_b8 (p2, p7, 0))
-
-/*
-** psel_p2_p7_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p7, p8\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p7_p8_w11, svbool_t,
- p2 = svpsel_b8 (p7, p8, w11),
- p2 = svpsel_b8 (p7, p8, w11))
-
-/*
-** psel_p7_p8_p13_w12:
-** psel p7, p8, p13\.b\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p7_p8_p13_w12, svbool_t,
- p7 = svpsel_b8 (p8, p13, w12),
- p7 = svpsel_b8 (p8, p13, w12))
-
-/*
-** psel_p8_p13_p15_w15:
-** psel p8, p13, p15\.b\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p8_p13_p15_w15, svbool_t,
- p8 = svpsel_b8 (p13, p15, w15),
- p8 = svpsel_b8 (p13, p15, w15))
-
-/*
-** psel_p13_p15_p0_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p15, p0\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p15_p0_w16, svbool_t,
- p13 = svpsel_b8 (p15, p0, w16),
- p13 = svpsel_b8 (p15, p0, w16))
-
-/*
-** psel_p15_p13_p8_w12p1:
-** psel p15, p13, p8\.b\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p13_p8_w12p1, svbool_t,
- p15 = svpsel_b8 (p13, p8, w12 + 1),
- p15 = svpsel_b8 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p8_p7_w12p15:
-** psel p13, p8, p7\.b\[w12, 15\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p8_p7_w12p15, svbool_t,
- p13 = svpsel_b8 (p8, p7, w12 + 15),
- p13 = svpsel_b8 (p8, p7, w12 + 15))
-
-/*
-** psel_p0_p0_p0_w12p16:
-** add (w[0-9]+), w12, #?16
-** psel p0, p0, p0\.b\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p0_w12p16, svbool_t,
- p0 = svpsel_b8 (p0, p0, w12 + 16),
- p0 = svpsel_b8 (p0, p0, w12 + 16))
-
-/*
-** psel_p15_p15_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p15, p15, p15\.b\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p15_p15_p15_w12m1, svbool_t,
- p15 = svpsel_b8 (p15, p15, w12 - 1),
- p15 = svpsel_b8 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c16.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c16.c
deleted file mode 100644
index 1cf45e6..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c16.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svcount_t,
- p0 = svpsel_c16 (p2, p7, 0),
- p0 = svpsel_c16 (p2, p7, 0))
-
-/*
-** psel_p2_p0_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p0, p8\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p0_p8_w11, svcount_t,
- p2 = svpsel_c16 (p0, p8, w11),
- p2 = svpsel_c16 (p0, p8, w11))
-
-/*
-** psel_p2_p13_p15_w12:
-** psel p2, p13, p15\.h\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p15_w12, svcount_t,
- p2 = svpsel_c16 (p13, p15, w12),
- p2 = svpsel_c16 (p13, p15, w12))
-
-/*
-** psel_p0_p13_p15_w15:
-** psel p0, p13, p15\.h\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p13_p15_w15, svcount_t,
- p0 = svpsel_c16 (p13, p15, w15),
- p0 = svpsel_c16 (p13, p15, w15))
-
-/*
-** psel_p13_p0_p15_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p0, p15\.h\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p15_w16, svcount_t,
- p13 = svpsel_c16 (p0, p15, w16),
- p13 = svpsel_c16 (p0, p15, w16))
-
-/*
-** psel_p2_p13_p8_w12p1:
-** psel p2, p13, p8\.h\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p8_w12p1, svcount_t,
- p2 = svpsel_c16 (p13, p8, w12 + 1),
- p2 = svpsel_c16 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p0_p7_w12p7:
-** psel p13, p0, p7\.h\[w12, 7\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p7_w12p7, svcount_t,
- p13 = svpsel_c16 (p0, p7, w12 + 7),
- p13 = svpsel_c16 (p0, p7, w12 + 7))
-
-/*
-** psel_p0_p0_p15_w12p8:
-** add (w[0-9]+), w12, #?8
-** psel p0, p0, p15\.h\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p15_w12p8, svcount_t,
- p0 = svpsel_c16 (p0, p15, w12 + 8),
- p0 = svpsel_c16 (p0, p15, w12 + 8))
-
-/*
-** psel_p13_p13_p7_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p13, p13, p7\.h\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p13_p7_w12m1, svcount_t,
- p13 = svpsel_c16 (p13, p7, w12 - 1),
- p13 = svpsel_c16 (p13, p7, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c32.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c32.c
deleted file mode 100644
index 5246a03..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c32.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svcount_t,
- p0 = svpsel_c32 (p2, p7, 0),
- p0 = svpsel_c32 (p2, p7, 0))
-
-/*
-** psel_p2_p13_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p13, p8\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p8_w11, svcount_t,
- p2 = svpsel_c32 (p13, p8, w11),
- p2 = svpsel_c32 (p13, p8, w11))
-
-/*
-** psel_p0_p13_p15_w12:
-** psel p0, p13, p15\.s\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p13_p15_w12, svcount_t,
- p0 = svpsel_c32 (p13, p15, w12),
- p0 = svpsel_c32 (p13, p15, w12))
-
-/*
-** psel_p2_p0_p15_w15:
-** psel p2, p0, p15\.s\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p0_p15_w15, svcount_t,
- p2 = svpsel_c32 (p0, p15, w15),
- p2 = svpsel_c32 (p0, p15, w15))
-
-/*
-** psel_p13_p0_p7_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p0, p7\.s\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p7_w16, svcount_t,
- p13 = svpsel_c32 (p0, p7, w16),
- p13 = svpsel_c32 (p0, p7, w16))
-
-/*
-** psel_p2_p13_p8_w12p1:
-** psel p2, p13, p8\.s\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p8_w12p1, svcount_t,
- p2 = svpsel_c32 (p13, p8, w12 + 1),
- p2 = svpsel_c32 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p0_p7_w12p3:
-** psel p13, p0, p7\.s\[w12, 3\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p7_w12p3, svcount_t,
- p13 = svpsel_c32 (p0, p7, w12 + 3),
- p13 = svpsel_c32 (p0, p7, w12 + 3))
-
-/*
-** psel_p0_p0_p7_w12p4:
-** add (w[0-9]+), w12, #?4
-** psel p0, p0, p7\.s\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p7_w12p4, svcount_t,
- p0 = svpsel_c32 (p0, p7, w12 + 4),
- p0 = svpsel_c32 (p0, p7, w12 + 4))
-
-/*
-** psel_p13_p13_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p13, p13, p15\.s\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p13_p15_w12m1, svcount_t,
- p13 = svpsel_c32 (p13, p15, w12 - 1),
- p13 = svpsel_c32 (p13, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c64.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c64.c
deleted file mode 100644
index 97304fd..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c64.c
+++ /dev/null
@@ -1,80 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svcount_t,
- p0 = svpsel_c64 (p2, p7, 0),
- p0 = svpsel_c64 (p2, p7, 0))
-
-/*
-** psel_p2_p13_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p13, p8\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p8_w11, svcount_t,
- p2 = svpsel_c64 (p13, p8, w11),
- p2 = svpsel_c64 (p13, p8, w11))
-
-/*
-** psel_p2_p0_p15_w12:
-** psel p2, p0, p15\.d\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p0_p15_w12, svcount_t,
- p2 = svpsel_c64 (p0, p15, w12),
- p2 = svpsel_c64 (p0, p15, w12))
-
-/*
-** psel_p0_p13_p15_w15:
-** psel p0, p13, p15\.d\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p13_p15_w15, svcount_t,
- p0 = svpsel_c64 (p13, p15, w15),
- p0 = svpsel_c64 (p13, p15, w15))
-
-/*
-** psel_p13_p0_p15_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p13, p0, p15\.d\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p15_w16, svcount_t,
- p13 = svpsel_c64 (p0, p15, w16),
- p13 = svpsel_c64 (p0, p15, w16))
-
-/*
-** psel_p2_p13_p8_w12p1:
-** psel p2, p13, p8\.d\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p8_w12p1, svcount_t,
- p2 = svpsel_c64 (p13, p8, w12 + 1),
- p2 = svpsel_c64 (p13, p8, w12 + 1))
-
-/*
-** psel_p0_p0_p8_w12p2:
-** add (w[0-9]+), w12, #?2
-** psel p0, p0, p8\.d\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p8_w12p2, svcount_t,
- p0 = svpsel_c64 (p0, p8, w12 + 2),
- p0 = svpsel_c64 (p0, p8, w12 + 2))
-
-/*
-** psel_p13_p13_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p13, p13, p15\.d\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p13_p15_w12m1, svcount_t,
- p13 = svpsel_c64 (p13, p15, w12 - 1),
- p13 = svpsel_c64 (p13, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c8.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c8.c
deleted file mode 100644
index 95973a1..0000000
--- a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_c8.c
+++ /dev/null
@@ -1,89 +0,0 @@
-/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
-
-#include "test_sme2_acle.h"
-
-/*
-** psel_p0_p2_p7_0:
-** mov [wx](1[2-5]), #?0
-** psel p0, p2, p7\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p2_p7_0, svcount_t,
- p0 = svpsel_c8 (p2, p7, 0),
- p0 = svpsel_c8 (p2, p7, 0))
-
-/*
-** psel_p2_p0_p8_w11:
-** mov [wx](1[2-5]), [wx]11
-** psel p2, p0, p8\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p0_p8_w11, svcount_t,
- p2 = svpsel_c8 (p0, p8, w11),
- p2 = svpsel_c8 (p0, p8, w11))
-
-/*
-** psel_p0_p13_p15_w12:
-** psel p0, p13, p15\.b\[w12, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p13_p15_w12, svcount_t,
- p0 = svpsel_c8 (p13, p15, w12),
- p0 = svpsel_c8 (p13, p15, w12))
-
-/*
-** psel_p13_p0_p8_w15:
-** psel p13, p0, p8\.b\[w15, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p0_p8_w15, svcount_t,
- p13 = svpsel_c8 (p0, p8, w15),
- p13 = svpsel_c8 (p0, p8, w15))
-
-/*
-** psel_p2_p13_p7_w16:
-** mov [wx](1[2-5]), [wx]16
-** psel p2, p13, p7\.b\[w\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p2_p13_p7_w16, svcount_t,
- p2 = svpsel_c8 (p13, p7, w16),
- p2 = svpsel_c8 (p13, p7, w16))
-
-/*
-** psel_p0_p13_p8_w12p1:
-** psel p0, p13, p8\.b\[w12, 1\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p13_p8_w12p1, svcount_t,
- p0 = svpsel_c8 (p13, p8, w12 + 1),
- p0 = svpsel_c8 (p13, p8, w12 + 1))
-
-/*
-** psel_p13_p2_p7_w12p15:
-** psel p13, p2, p7\.b\[w12, 15\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p2_p7_w12p15, svcount_t,
- p13 = svpsel_c8 (p2, p7, w12 + 15),
- p13 = svpsel_c8 (p2, p7, w12 + 15))
-
-/*
-** psel_p0_p0_p15_w12p16:
-** add (w[0-9]+), w12, #?16
-** psel p0, p0, p15\.b\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p0_p0_p15_w12p16, svcount_t,
- p0 = svpsel_c8 (p0, p15, w12 + 16),
- p0 = svpsel_c8 (p0, p15, w12 + 16))
-
-/*
-** psel_p13_p13_p15_w12m1:
-** sub (w[0-9]+), w12, #?1
-** psel p13, p13, p15\.b\[\1, 0\]
-** ret
-*/
-TEST_SELECT_P (psel_p13_p13_p15_w12m1, svcount_t,
- p13 = svpsel_c8 (p13, p15, w12 - 1),
- p13 = svpsel_c8 (p13, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b16.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b16.c
new file mode 100644
index 0000000..704e9e3
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b16.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svbool_t,
+ p0 = svpsel_lane_b16 (p2, p7, 0),
+ p0 = svpsel_lane_b16 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p7_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p7, p8\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p7_p8_w11, svbool_t,
+ p2 = svpsel_lane_b16 (p7, p8, w11),
+ p2 = svpsel_lane_b16 (p7, p8, w11))
+
+/*
+** psel_lane_p7_p8_p13_w12:
+** psel p7, p8, p13\.h\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p7_p8_p13_w12, svbool_t,
+ p7 = svpsel_lane_b16 (p8, p13, w12),
+ p7 = svpsel_lane_b16 (p8, p13, w12))
+
+/*
+** psel_lane_p8_p13_p15_w15:
+** psel p8, p13, p15\.h\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p8_p13_p15_w15, svbool_t,
+ p8 = svpsel_lane_b16 (p13, p15, w15),
+ p8 = svpsel_lane_b16 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p15_p0_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p15, p0\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p15_p0_w16, svbool_t,
+ p13 = svpsel_lane_b16 (p15, p0, w16),
+ p13 = svpsel_lane_b16 (p15, p0, w16))
+
+/*
+** psel_lane_p15_p13_p8_w12p1:
+** psel p15, p13, p8\.h\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p13_p8_w12p1, svbool_t,
+ p15 = svpsel_lane_b16 (p13, p8, w12 + 1),
+ p15 = svpsel_lane_b16 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p8_p7_w12p7:
+** psel p13, p8, p7\.h\[w12, 7\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p8_p7_w12p7, svbool_t,
+ p13 = svpsel_lane_b16 (p8, p7, w12 + 7),
+ p13 = svpsel_lane_b16 (p8, p7, w12 + 7))
+
+/*
+** psel_lane_p0_p0_p0_w12p8:
+** add (w[0-9]+), w12, #?8
+** psel p0, p0, p0\.h\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p0_w12p8, svbool_t,
+ p0 = svpsel_lane_b16 (p0, p0, w12 + 8),
+ p0 = svpsel_lane_b16 (p0, p0, w12 + 8))
+
+/*
+** psel_lane_p15_p15_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p15, p15, p15\.h\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p15_p15_w12m1, svbool_t,
+ p15 = svpsel_lane_b16 (p15, p15, w12 - 1),
+ p15 = svpsel_lane_b16 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b32.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b32.c
new file mode 100644
index 0000000..7d9c7a1
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b32.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svbool_t,
+ p0 = svpsel_lane_b32 (p2, p7, 0),
+ p0 = svpsel_lane_b32 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p7_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p7, p8\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p7_p8_w11, svbool_t,
+ p2 = svpsel_lane_b32 (p7, p8, w11),
+ p2 = svpsel_lane_b32 (p7, p8, w11))
+
+/*
+** psel_lane_p7_p8_p13_w12:
+** psel p7, p8, p13\.s\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p7_p8_p13_w12, svbool_t,
+ p7 = svpsel_lane_b32 (p8, p13, w12),
+ p7 = svpsel_lane_b32 (p8, p13, w12))
+
+/*
+** psel_lane_p8_p13_p15_w15:
+** psel p8, p13, p15\.s\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p8_p13_p15_w15, svbool_t,
+ p8 = svpsel_lane_b32 (p13, p15, w15),
+ p8 = svpsel_lane_b32 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p15_p0_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p15, p0\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p15_p0_w16, svbool_t,
+ p13 = svpsel_lane_b32 (p15, p0, w16),
+ p13 = svpsel_lane_b32 (p15, p0, w16))
+
+/*
+** psel_lane_p15_p13_p8_w12p1:
+** psel p15, p13, p8\.s\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p13_p8_w12p1, svbool_t,
+ p15 = svpsel_lane_b32 (p13, p8, w12 + 1),
+ p15 = svpsel_lane_b32 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p8_p7_w12p3:
+** psel p13, p8, p7\.s\[w12, 3\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p8_p7_w12p3, svbool_t,
+ p13 = svpsel_lane_b32 (p8, p7, w12 + 3),
+ p13 = svpsel_lane_b32 (p8, p7, w12 + 3))
+
+/*
+** psel_lane_p0_p0_p0_w12p4:
+** add (w[0-9]+), w12, #?4
+** psel p0, p0, p0\.s\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p0_w12p4, svbool_t,
+ p0 = svpsel_lane_b32 (p0, p0, w12 + 4),
+ p0 = svpsel_lane_b32 (p0, p0, w12 + 4))
+
+/*
+** psel_lane_p15_p15_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p15, p15, p15\.s\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p15_p15_w12m1, svbool_t,
+ p15 = svpsel_lane_b32 (p15, p15, w12 - 1),
+ p15 = svpsel_lane_b32 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b64.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b64.c
new file mode 100644
index 0000000..a59032a
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b64.c
@@ -0,0 +1,80 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svbool_t,
+ p0 = svpsel_lane_b64 (p2, p7, 0),
+ p0 = svpsel_lane_b64 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p7_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p7, p8\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p7_p8_w11, svbool_t,
+ p2 = svpsel_lane_b64 (p7, p8, w11),
+ p2 = svpsel_lane_b64 (p7, p8, w11))
+
+/*
+** psel_lane_p7_p8_p13_w12:
+** psel p7, p8, p13\.d\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p7_p8_p13_w12, svbool_t,
+ p7 = svpsel_lane_b64 (p8, p13, w12),
+ p7 = svpsel_lane_b64 (p8, p13, w12))
+
+/*
+** psel_lane_p8_p13_p15_w15:
+** psel p8, p13, p15\.d\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p8_p13_p15_w15, svbool_t,
+ p8 = svpsel_lane_b64 (p13, p15, w15),
+ p8 = svpsel_lane_b64 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p15_p0_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p15, p0\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p15_p0_w16, svbool_t,
+ p13 = svpsel_lane_b64 (p15, p0, w16),
+ p13 = svpsel_lane_b64 (p15, p0, w16))
+
+/*
+** psel_lane_p15_p13_p8_w12p1:
+** psel p15, p13, p8\.d\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p13_p8_w12p1, svbool_t,
+ p15 = svpsel_lane_b64 (p13, p8, w12 + 1),
+ p15 = svpsel_lane_b64 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p0_p0_p0_w12p2:
+** add (w[0-9]+), w12, #?2
+** psel p0, p0, p0\.d\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p0_w12p2, svbool_t,
+ p0 = svpsel_lane_b64 (p0, p0, w12 + 2),
+ p0 = svpsel_lane_b64 (p0, p0, w12 + 2))
+
+/*
+** psel_lane_p15_p15_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p15, p15, p15\.d\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p15_p15_w12m1, svbool_t,
+ p15 = svpsel_lane_b64 (p15, p15, w12 - 1),
+ p15 = svpsel_lane_b64 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b8.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b8.c
new file mode 100644
index 0000000..0dea85c
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_b8.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svbool_t,
+ p0 = svpsel_lane_b8 (p2, p7, 0),
+ p0 = svpsel_lane_b8 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p7_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p7, p8\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p7_p8_w11, svbool_t,
+ p2 = svpsel_lane_b8 (p7, p8, w11),
+ p2 = svpsel_lane_b8 (p7, p8, w11))
+
+/*
+** psel_lane_p7_p8_p13_w12:
+** psel p7, p8, p13\.b\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p7_p8_p13_w12, svbool_t,
+ p7 = svpsel_lane_b8 (p8, p13, w12),
+ p7 = svpsel_lane_b8 (p8, p13, w12))
+
+/*
+** psel_lane_p8_p13_p15_w15:
+** psel p8, p13, p15\.b\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p8_p13_p15_w15, svbool_t,
+ p8 = svpsel_lane_b8 (p13, p15, w15),
+ p8 = svpsel_lane_b8 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p15_p0_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p15, p0\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p15_p0_w16, svbool_t,
+ p13 = svpsel_lane_b8 (p15, p0, w16),
+ p13 = svpsel_lane_b8 (p15, p0, w16))
+
+/*
+** psel_lane_p15_p13_p8_w12p1:
+** psel p15, p13, p8\.b\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p13_p8_w12p1, svbool_t,
+ p15 = svpsel_lane_b8 (p13, p8, w12 + 1),
+ p15 = svpsel_lane_b8 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p8_p7_w12p15:
+** psel p13, p8, p7\.b\[w12, 15\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p8_p7_w12p15, svbool_t,
+ p13 = svpsel_lane_b8 (p8, p7, w12 + 15),
+ p13 = svpsel_lane_b8 (p8, p7, w12 + 15))
+
+/*
+** psel_lane_p0_p0_p0_w12p16:
+** add (w[0-9]+), w12, #?16
+** psel p0, p0, p0\.b\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p0_w12p16, svbool_t,
+ p0 = svpsel_lane_b8 (p0, p0, w12 + 16),
+ p0 = svpsel_lane_b8 (p0, p0, w12 + 16))
+
+/*
+** psel_lane_p15_p15_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p15, p15, p15\.b\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p15_p15_p15_w12m1, svbool_t,
+ p15 = svpsel_lane_b8 (p15, p15, w12 - 1),
+ p15 = svpsel_lane_b8 (p15, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c16.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c16.c
new file mode 100644
index 0000000..039c72b
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c16.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svcount_t,
+ p0 = svpsel_lane_c16 (p2, p7, 0),
+ p0 = svpsel_lane_c16 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p0_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p0, p8\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p0_p8_w11, svcount_t,
+ p2 = svpsel_lane_c16 (p0, p8, w11),
+ p2 = svpsel_lane_c16 (p0, p8, w11))
+
+/*
+** psel_lane_p2_p13_p15_w12:
+** psel p2, p13, p15\.h\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p15_w12, svcount_t,
+ p2 = svpsel_lane_c16 (p13, p15, w12),
+ p2 = svpsel_lane_c16 (p13, p15, w12))
+
+/*
+** psel_lane_p0_p13_p15_w15:
+** psel p0, p13, p15\.h\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p13_p15_w15, svcount_t,
+ p0 = svpsel_lane_c16 (p13, p15, w15),
+ p0 = svpsel_lane_c16 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p0_p15_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p0, p15\.h\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p15_w16, svcount_t,
+ p13 = svpsel_lane_c16 (p0, p15, w16),
+ p13 = svpsel_lane_c16 (p0, p15, w16))
+
+/*
+** psel_lane_p2_p13_p8_w12p1:
+** psel p2, p13, p8\.h\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p8_w12p1, svcount_t,
+ p2 = svpsel_lane_c16 (p13, p8, w12 + 1),
+ p2 = svpsel_lane_c16 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p0_p7_w12p7:
+** psel p13, p0, p7\.h\[w12, 7\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p7_w12p7, svcount_t,
+ p13 = svpsel_lane_c16 (p0, p7, w12 + 7),
+ p13 = svpsel_lane_c16 (p0, p7, w12 + 7))
+
+/*
+** psel_lane_p0_p0_p15_w12p8:
+** add (w[0-9]+), w12, #?8
+** psel p0, p0, p15\.h\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p15_w12p8, svcount_t,
+ p0 = svpsel_lane_c16 (p0, p15, w12 + 8),
+ p0 = svpsel_lane_c16 (p0, p15, w12 + 8))
+
+/*
+** psel_lane_p13_p13_p7_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p13, p13, p7\.h\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p13_p7_w12m1, svcount_t,
+ p13 = svpsel_lane_c16 (p13, p7, w12 - 1),
+ p13 = svpsel_lane_c16 (p13, p7, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c32.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c32.c
new file mode 100644
index 0000000..eaf195d
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c32.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svcount_t,
+ p0 = svpsel_lane_c32 (p2, p7, 0),
+ p0 = svpsel_lane_c32 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p13_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p13, p8\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p8_w11, svcount_t,
+ p2 = svpsel_lane_c32 (p13, p8, w11),
+ p2 = svpsel_lane_c32 (p13, p8, w11))
+
+/*
+** psel_lane_p0_p13_p15_w12:
+** psel p0, p13, p15\.s\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p13_p15_w12, svcount_t,
+ p0 = svpsel_lane_c32 (p13, p15, w12),
+ p0 = svpsel_lane_c32 (p13, p15, w12))
+
+/*
+** psel_lane_p2_p0_p15_w15:
+** psel p2, p0, p15\.s\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p0_p15_w15, svcount_t,
+ p2 = svpsel_lane_c32 (p0, p15, w15),
+ p2 = svpsel_lane_c32 (p0, p15, w15))
+
+/*
+** psel_lane_p13_p0_p7_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p0, p7\.s\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p7_w16, svcount_t,
+ p13 = svpsel_lane_c32 (p0, p7, w16),
+ p13 = svpsel_lane_c32 (p0, p7, w16))
+
+/*
+** psel_lane_p2_p13_p8_w12p1:
+** psel p2, p13, p8\.s\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p8_w12p1, svcount_t,
+ p2 = svpsel_lane_c32 (p13, p8, w12 + 1),
+ p2 = svpsel_lane_c32 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p0_p7_w12p3:
+** psel p13, p0, p7\.s\[w12, 3\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p7_w12p3, svcount_t,
+ p13 = svpsel_lane_c32 (p0, p7, w12 + 3),
+ p13 = svpsel_lane_c32 (p0, p7, w12 + 3))
+
+/*
+** psel_lane_p0_p0_p7_w12p4:
+** add (w[0-9]+), w12, #?4
+** psel p0, p0, p7\.s\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p7_w12p4, svcount_t,
+ p0 = svpsel_lane_c32 (p0, p7, w12 + 4),
+ p0 = svpsel_lane_c32 (p0, p7, w12 + 4))
+
+/*
+** psel_lane_p13_p13_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p13, p13, p15\.s\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p13_p15_w12m1, svcount_t,
+ p13 = svpsel_lane_c32 (p13, p15, w12 - 1),
+ p13 = svpsel_lane_c32 (p13, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c64.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c64.c
new file mode 100644
index 0000000..70cfeca
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c64.c
@@ -0,0 +1,80 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svcount_t,
+ p0 = svpsel_lane_c64 (p2, p7, 0),
+ p0 = svpsel_lane_c64 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p13_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p13, p8\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p8_w11, svcount_t,
+ p2 = svpsel_lane_c64 (p13, p8, w11),
+ p2 = svpsel_lane_c64 (p13, p8, w11))
+
+/*
+** psel_lane_p2_p0_p15_w12:
+** psel p2, p0, p15\.d\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p0_p15_w12, svcount_t,
+ p2 = svpsel_lane_c64 (p0, p15, w12),
+ p2 = svpsel_lane_c64 (p0, p15, w12))
+
+/*
+** psel_lane_p0_p13_p15_w15:
+** psel p0, p13, p15\.d\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p13_p15_w15, svcount_t,
+ p0 = svpsel_lane_c64 (p13, p15, w15),
+ p0 = svpsel_lane_c64 (p13, p15, w15))
+
+/*
+** psel_lane_p13_p0_p15_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p13, p0, p15\.d\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p15_w16, svcount_t,
+ p13 = svpsel_lane_c64 (p0, p15, w16),
+ p13 = svpsel_lane_c64 (p0, p15, w16))
+
+/*
+** psel_lane_p2_p13_p8_w12p1:
+** psel p2, p13, p8\.d\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p8_w12p1, svcount_t,
+ p2 = svpsel_lane_c64 (p13, p8, w12 + 1),
+ p2 = svpsel_lane_c64 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p0_p0_p8_w12p2:
+** add (w[0-9]+), w12, #?2
+** psel p0, p0, p8\.d\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p8_w12p2, svcount_t,
+ p0 = svpsel_lane_c64 (p0, p8, w12 + 2),
+ p0 = svpsel_lane_c64 (p0, p8, w12 + 2))
+
+/*
+** psel_lane_p13_p13_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p13, p13, p15\.d\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p13_p15_w12m1, svcount_t,
+ p13 = svpsel_lane_c64 (p13, p15, w12 - 1),
+ p13 = svpsel_lane_c64 (p13, p15, w12 - 1))
diff --git a/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c8.c b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c8.c
new file mode 100644
index 0000000..b017962
--- /dev/null
+++ b/gcc/testsuite/gcc.target/aarch64/sme2/acle-asm/psel_lane_c8.c
@@ -0,0 +1,89 @@
+/* { dg-final { check-function-bodies "**" "" "-DCHECK_ASM" } } */
+
+#include "test_sme2_acle.h"
+
+/*
+** psel_lane_p0_p2_p7_0:
+** mov [wx](1[2-5]), #?0
+** psel p0, p2, p7\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p2_p7_0, svcount_t,
+ p0 = svpsel_lane_c8 (p2, p7, 0),
+ p0 = svpsel_lane_c8 (p2, p7, 0))
+
+/*
+** psel_lane_p2_p0_p8_w11:
+** mov [wx](1[2-5]), [wx]11
+** psel p2, p0, p8\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p0_p8_w11, svcount_t,
+ p2 = svpsel_lane_c8 (p0, p8, w11),
+ p2 = svpsel_lane_c8 (p0, p8, w11))
+
+/*
+** psel_lane_p0_p13_p15_w12:
+** psel p0, p13, p15\.b\[w12, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p13_p15_w12, svcount_t,
+ p0 = svpsel_lane_c8 (p13, p15, w12),
+ p0 = svpsel_lane_c8 (p13, p15, w12))
+
+/*
+** psel_lane_p13_p0_p8_w15:
+** psel p13, p0, p8\.b\[w15, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p0_p8_w15, svcount_t,
+ p13 = svpsel_lane_c8 (p0, p8, w15),
+ p13 = svpsel_lane_c8 (p0, p8, w15))
+
+/*
+** psel_lane_p2_p13_p7_w16:
+** mov [wx](1[2-5]), [wx]16
+** psel p2, p13, p7\.b\[w\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p2_p13_p7_w16, svcount_t,
+ p2 = svpsel_lane_c8 (p13, p7, w16),
+ p2 = svpsel_lane_c8 (p13, p7, w16))
+
+/*
+** psel_lane_p0_p13_p8_w12p1:
+** psel p0, p13, p8\.b\[w12, 1\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p13_p8_w12p1, svcount_t,
+ p0 = svpsel_lane_c8 (p13, p8, w12 + 1),
+ p0 = svpsel_lane_c8 (p13, p8, w12 + 1))
+
+/*
+** psel_lane_p13_p2_p7_w12p15:
+** psel p13, p2, p7\.b\[w12, 15\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p2_p7_w12p15, svcount_t,
+ p13 = svpsel_lane_c8 (p2, p7, w12 + 15),
+ p13 = svpsel_lane_c8 (p2, p7, w12 + 15))
+
+/*
+** psel_lane_p0_p0_p15_w12p16:
+** add (w[0-9]+), w12, #?16
+** psel p0, p0, p15\.b\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p0_p0_p15_w12p16, svcount_t,
+ p0 = svpsel_lane_c8 (p0, p15, w12 + 16),
+ p0 = svpsel_lane_c8 (p0, p15, w12 + 16))
+
+/*
+** psel_lane_p13_p13_p15_w12m1:
+** sub (w[0-9]+), w12, #?1
+** psel p13, p13, p15\.b\[\1, 0\]
+** ret
+*/
+TEST_SELECT_P (psel_lane_p13_p13_p15_w12m1, svcount_t,
+ p13 = svpsel_lane_c8 (p13, p15, w12 - 1),
+ p13 = svpsel_lane_c8 (p13, p15, w12 - 1))