* [PATCH v2][ARM][GCC][11x]: MVE ACLE vector interleaving store and deinterleaving load intrinsics and also aliases to vstr and vldr intrinsics.
@ 2020-03-20 16:42 Srinath Parvathaneni
2020-03-20 16:58 ` Kyrylo Tkachov
0 siblings, 1 reply; 2+ messages in thread
From: Srinath Parvathaneni @ 2020-03-20 16:42 UTC (permalink / raw)
To: gcc-patches
[-- Attachment #1: Type: text/plain, Size: 72000 bytes --]
Hello Kyrill,
Following patch is the rebased version of v1.
(version v1) https://gcc.gnu.org/pipermail/gcc-patches/2019-November/534347.html
####
Hello,
This patch supports following MVE ACLE intrinsics which are aliases of vstr and
vldr intrinsics.
vst1q_p_u8, vst1q_p_s8, vld1q_z_u8, vld1q_z_s8, vst1q_p_u16, vst1q_p_s16,
vld1q_z_u16, vld1q_z_s16, vst1q_p_u32, vst1q_p_s32, vld1q_z_u32, vld1q_z_s32,
vld1q_z_f16, vst1q_p_f16, vld1q_z_f32, vst1q_p_f32.
This patch also supports following MVE ACLE vector deinterleaving loads and vector
interleaving stores.
vst2q_s8, vst2q_u8, vld2q_s8, vld2q_u8, vld4q_s8, vld4q_u8, vst2q_s16, vst2q_u16,
vld2q_s16, vld2q_u16, vld4q_s16, vld4q_u16, vst2q_s32, vst2q_u32, vld2q_s32,
vld2q_u32, vld4q_s32, vld4q_u32, vld4q_f16, vld2q_f16, vst2q_f16, vld4q_f32,
vld2q_f32, vst2q_f32.
Please refer to M-profile Vector Extension (MVE) intrinsics [1] for more details.
[1] https://developer.arm.com/architectures/instruction-sets/simd-isas/helium/mve-intrinsics
Regression tested on arm-none-eabi and found no regressions.
Ok for trunk?
Thanks,
Srinath.
gcc/ChangeLog:
2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
Andre Vieira <andre.simoesdiasvieira@arm.com>
Mihail Ionescu <mihail.ionescu@arm.com>
* config/arm/arm_mve.h (vst1q_p_u8): Define macro.
(vst1q_p_s8): Likewise.
(vst2q_s8): Likewise.
(vst2q_u8): Likewise.
(vld1q_z_u8): Likewise.
(vld1q_z_s8): Likewise.
(vld2q_s8): Likewise.
(vld2q_u8): Likewise.
(vld4q_s8): Likewise.
(vld4q_u8): Likewise.
(vst1q_p_u16): Likewise.
(vst1q_p_s16): Likewise.
(vst2q_s16): Likewise.
(vst2q_u16): Likewise.
(vld1q_z_u16): Likewise.
(vld1q_z_s16): Likewise.
(vld2q_s16): Likewise.
(vld2q_u16): Likewise.
(vld4q_s16): Likewise.
(vld4q_u16): Likewise.
(vst1q_p_u32): Likewise.
(vst1q_p_s32): Likewise.
(vst2q_s32): Likewise.
(vst2q_u32): Likewise.
(vld1q_z_u32): Likewise.
(vld1q_z_s32): Likewise.
(vld2q_s32): Likewise.
(vld2q_u32): Likewise.
(vld4q_s32): Likewise.
(vld4q_u32): Likewise.
(vld4q_f16): Likewise.
(vld2q_f16): Likewise.
(vld1q_z_f16): Likewise.
(vst2q_f16): Likewise.
(vst1q_p_f16): Likewise.
(vld4q_f32): Likewise.
(vld2q_f32): Likewise.
(vld1q_z_f32): Likewise.
(vst2q_f32): Likewise.
(vst1q_p_f32): Likewise.
(__arm_vst1q_p_u8): Define intrinsic.
(__arm_vst1q_p_s8): Likewise.
(__arm_vst2q_s8): Likewise.
(__arm_vst2q_u8): Likewise.
(__arm_vld1q_z_u8): Likewise.
(__arm_vld1q_z_s8): Likewise.
(__arm_vld2q_s8): Likewise.
(__arm_vld2q_u8): Likewise.
(__arm_vld4q_s8): Likewise.
(__arm_vld4q_u8): Likewise.
(__arm_vst1q_p_u16): Likewise.
(__arm_vst1q_p_s16): Likewise.
(__arm_vst2q_s16): Likewise.
(__arm_vst2q_u16): Likewise.
(__arm_vld1q_z_u16): Likewise.
(__arm_vld1q_z_s16): Likewise.
(__arm_vld2q_s16): Likewise.
(__arm_vld2q_u16): Likewise.
(__arm_vld4q_s16): Likewise.
(__arm_vld4q_u16): Likewise.
(__arm_vst1q_p_u32): Likewise.
(__arm_vst1q_p_s32): Likewise.
(__arm_vst2q_s32): Likewise.
(__arm_vst2q_u32): Likewise.
(__arm_vld1q_z_u32): Likewise.
(__arm_vld1q_z_s32): Likewise.
(__arm_vld2q_s32): Likewise.
(__arm_vld2q_u32): Likewise.
(__arm_vld4q_s32): Likewise.
(__arm_vld4q_u32): Likewise.
(__arm_vld4q_f16): Likewise.
(__arm_vld2q_f16): Likewise.
(__arm_vld1q_z_f16): Likewise.
(__arm_vst2q_f16): Likewise.
(__arm_vst1q_p_f16): Likewise.
(__arm_vld4q_f32): Likewise.
(__arm_vld2q_f32): Likewise.
(__arm_vld1q_z_f32): Likewise.
(__arm_vst2q_f32): Likewise.
(__arm_vst1q_p_f32): Likewise.
(vld1q_z): Define polymorphic variant.
(vld2q): Likewise.
(vld4q): Likewise.
(vst1q_p): Likewise.
(vst2q): Likewise.
* config/arm/arm_mve_builtins.def (STORE1): Use builtin qualifier.
(LOAD1): Likewise.
* config/arm/mve.md (mve_vst2q<mode>): Define RTL pattern.
(mve_vld2q<mode>): Likewise.
(mve_vld4q<mode>): Likewise.
gcc/testsuite/ChangeLog:
2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
Andre Vieira <andre.simoesdiasvieira@arm.com>
Mihail Ionescu <mihail.ionescu@arm.com>
* gcc.target/arm/mve/intrinsics/vld1q_z_f16.c: New test.
* gcc.target/arm/mve/intrinsics/vld1q_z_f32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_s16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_s32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_s8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_u16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_u32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld1q_z_u8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_f16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_f32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_s16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_s32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_s8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_u16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_u32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld2q_u8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_f16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_f32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_s16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_s32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_s8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_u16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_u32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vld4q_u8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_f16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_f32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_s16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_s32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_s8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_u16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_u32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst1q_p_u8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_f16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_f32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_s16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_s32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_s8.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_u16.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_u32.c: Likewise.
* gcc.target/arm/mve/intrinsics/vst2q_u8.c: Likewise.
############### Attachment also inlined for ease of reply ###############
diff --git a/gcc/config/arm/arm_mve.h b/gcc/config/arm/arm_mve.h
index 220319cffd711323e5f72ba49407f4237f70ebf3..f6810ddf4b735e1cd782a67c2d48bab8ddb75814 100644
--- a/gcc/config/arm/arm_mve.h
+++ b/gcc/config/arm/arm_mve.h
@@ -2466,6 +2466,46 @@ typedef struct { uint8x16_t val[4]; } uint8x16x4_t;
#define vsbcq_u32(__a, __b, __carry) __arm_vsbcq_u32(__a, __b, __carry)
#define vsbcq_m_s32(__inactive, __a, __b, __carry, __p) __arm_vsbcq_m_s32(__inactive, __a, __b, __carry, __p)
#define vsbcq_m_u32(__inactive, __a, __b, __carry, __p) __arm_vsbcq_m_u32(__inactive, __a, __b, __carry, __p)
+#define vst1q_p_u8(__addr, __value, __p) __arm_vst1q_p_u8(__addr, __value, __p)
+#define vst1q_p_s8(__addr, __value, __p) __arm_vst1q_p_s8(__addr, __value, __p)
+#define vst2q_s8(__addr, __value) __arm_vst2q_s8(__addr, __value)
+#define vst2q_u8(__addr, __value) __arm_vst2q_u8(__addr, __value)
+#define vld1q_z_u8(__base, __p) __arm_vld1q_z_u8(__base, __p)
+#define vld1q_z_s8(__base, __p) __arm_vld1q_z_s8(__base, __p)
+#define vld2q_s8(__addr) __arm_vld2q_s8(__addr)
+#define vld2q_u8(__addr) __arm_vld2q_u8(__addr)
+#define vld4q_s8(__addr) __arm_vld4q_s8(__addr)
+#define vld4q_u8(__addr) __arm_vld4q_u8(__addr)
+#define vst1q_p_u16(__addr, __value, __p) __arm_vst1q_p_u16(__addr, __value, __p)
+#define vst1q_p_s16(__addr, __value, __p) __arm_vst1q_p_s16(__addr, __value, __p)
+#define vst2q_s16(__addr, __value) __arm_vst2q_s16(__addr, __value)
+#define vst2q_u16(__addr, __value) __arm_vst2q_u16(__addr, __value)
+#define vld1q_z_u16(__base, __p) __arm_vld1q_z_u16(__base, __p)
+#define vld1q_z_s16(__base, __p) __arm_vld1q_z_s16(__base, __p)
+#define vld2q_s16(__addr) __arm_vld2q_s16(__addr)
+#define vld2q_u16(__addr) __arm_vld2q_u16(__addr)
+#define vld4q_s16(__addr) __arm_vld4q_s16(__addr)
+#define vld4q_u16(__addr) __arm_vld4q_u16(__addr)
+#define vst1q_p_u32(__addr, __value, __p) __arm_vst1q_p_u32(__addr, __value, __p)
+#define vst1q_p_s32(__addr, __value, __p) __arm_vst1q_p_s32(__addr, __value, __p)
+#define vst2q_s32(__addr, __value) __arm_vst2q_s32(__addr, __value)
+#define vst2q_u32(__addr, __value) __arm_vst2q_u32(__addr, __value)
+#define vld1q_z_u32(__base, __p) __arm_vld1q_z_u32(__base, __p)
+#define vld1q_z_s32(__base, __p) __arm_vld1q_z_s32(__base, __p)
+#define vld2q_s32(__addr) __arm_vld2q_s32(__addr)
+#define vld2q_u32(__addr) __arm_vld2q_u32(__addr)
+#define vld4q_s32(__addr) __arm_vld4q_s32(__addr)
+#define vld4q_u32(__addr) __arm_vld4q_u32(__addr)
+#define vld4q_f16(__addr) __arm_vld4q_f16(__addr)
+#define vld2q_f16(__addr) __arm_vld2q_f16(__addr)
+#define vld1q_z_f16(__base, __p) __arm_vld1q_z_f16(__base, __p)
+#define vst2q_f16(__addr, __value) __arm_vst2q_f16(__addr, __value)
+#define vst1q_p_f16(__addr, __value, __p) __arm_vst1q_p_f16(__addr, __value, __p)
+#define vld4q_f32(__addr) __arm_vld4q_f32(__addr)
+#define vld2q_f32(__addr) __arm_vld2q_f32(__addr)
+#define vld1q_z_f32(__base, __p) __arm_vld1q_z_f32(__base, __p)
+#define vst2q_f32(__addr, __value) __arm_vst2q_f32(__addr, __value)
+#define vst1q_p_f32(__addr, __value, __p) __arm_vst1q_p_f32(__addr, __value, __p)
#endif
__extension__ extern __inline void
@@ -16085,6 +16125,252 @@ __arm_vsbcq_m_u32 (uint32x4_t __inactive, uint32x4_t __a, uint32x4_t __b, unsign
return __res;
}
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_u8 (uint8_t * __addr, uint8x16_t __value, mve_pred16_t __p)
+{
+ return vstrbq_p_u8 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_s8 (int8_t * __addr, int8x16_t __value, mve_pred16_t __p)
+{
+ return vstrbq_p_s8 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_s8 (int8_t * __addr, int8x16x2_t __value)
+{
+ union { int8x16x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv16qi ((__builtin_neon_qi *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_u8 (uint8_t * __addr, uint8x16x2_t __value)
+{
+ union { uint8x16x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv16qi ((__builtin_neon_qi *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline uint8x16_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_u8 (uint8_t const *__base, mve_pred16_t __p)
+{
+ return vldrbq_z_u8 ( __base, __p);
+}
+
+__extension__ extern __inline int8x16_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_s8 (int8_t const *__base, mve_pred16_t __p)
+{
+ return vldrbq_z_s8 ( __base, __p);
+}
+
+__extension__ extern __inline int8x16x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_s8 (int8_t const * __addr)
+{
+ union { int8x16x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv16qi ((__builtin_neon_qi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint8x16x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_u8 (uint8_t const * __addr)
+{
+ union { uint8x16x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv16qi ((__builtin_neon_qi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline int8x16x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_s8 (int8_t const * __addr)
+{
+ union { int8x16x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv16qi ((__builtin_neon_qi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint8x16x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_u8 (uint8_t const * __addr)
+{
+ union { uint8x16x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv16qi ((__builtin_neon_qi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_u16 (uint16_t * __addr, uint16x8_t __value, mve_pred16_t __p)
+{
+ return vstrhq_p_u16 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_s16 (int16_t * __addr, int16x8_t __value, mve_pred16_t __p)
+{
+ return vstrhq_p_s16 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_s16 (int16_t * __addr, int16x8x2_t __value)
+{
+ union { int16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv8hi ((__builtin_neon_hi *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_u16 (uint16_t * __addr, uint16x8x2_t __value)
+{
+ union { uint16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv8hi ((__builtin_neon_hi *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline uint16x8_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_u16 (uint16_t const *__base, mve_pred16_t __p)
+{
+ return vldrhq_z_u16 ( __base, __p);
+}
+
+__extension__ extern __inline int16x8_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_s16 (int16_t const *__base, mve_pred16_t __p)
+{
+ return vldrhq_z_s16 ( __base, __p);
+}
+
+__extension__ extern __inline int16x8x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_s16 (int16_t const * __addr)
+{
+ union { int16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv8hi ((__builtin_neon_hi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint16x8x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_u16 (uint16_t const * __addr)
+{
+ union { uint16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv8hi ((__builtin_neon_hi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline int16x8x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_s16 (int16_t const * __addr)
+{
+ union { int16x8x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv8hi ((__builtin_neon_hi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint16x8x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_u16 (uint16_t const * __addr)
+{
+ union { uint16x8x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv8hi ((__builtin_neon_hi *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_u32 (uint32_t * __addr, uint32x4_t __value, mve_pred16_t __p)
+{
+ return vstrwq_p_u32 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_s32 (int32_t * __addr, int32x4_t __value, mve_pred16_t __p)
+{
+ return vstrwq_p_s32 (__addr, __value, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_s32 (int32_t * __addr, int32x4x2_t __value)
+{
+ union { int32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv4si ((__builtin_neon_si *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_u32 (uint32_t * __addr, uint32x4x2_t __value)
+{
+ union { uint32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv4si ((__builtin_neon_si *) __addr, __rv.__o);
+}
+
+__extension__ extern __inline uint32x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_u32 (uint32_t const *__base, mve_pred16_t __p)
+{
+ return vldrwq_z_u32 ( __base, __p);
+}
+
+__extension__ extern __inline int32x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_s32 (int32_t const *__base, mve_pred16_t __p)
+{
+ return vldrwq_z_s32 ( __base, __p);
+}
+
+__extension__ extern __inline int32x4x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_s32 (int32_t const * __addr)
+{
+ union { int32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv4si ((__builtin_neon_si *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint32x4x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_u32 (uint32_t const * __addr)
+{
+ union { uint32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv4si ((__builtin_neon_si *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline int32x4x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_s32 (int32_t const * __addr)
+{
+ union { int32x4x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv4si ((__builtin_neon_si *) __addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline uint32x4x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_u32 (uint32_t const * __addr)
+{
+ union { uint32x4x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv4si ((__builtin_neon_si *) __addr);
+ return __rv.__i;
+}
+
#if (__ARM_FEATURE_MVE & 2) /* MVE Floating point. */
__extension__ extern __inline void
@@ -19436,6 +19722,88 @@ __arm_vrev64q_x_f32 (float32x4_t __a, mve_pred16_t __p)
return __builtin_mve_vrev64q_m_fv4sf (vuninitializedq_f32 (), __a, __p);
}
+__extension__ extern __inline float16x8x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_f16 (float16_t const * __addr)
+{
+ union { float16x8x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv8hf (__addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline float16x8x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_f16 (float16_t const * __addr)
+{
+ union { float16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv8hf (__addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline float16x8_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_f16 (float16_t const *__base, mve_pred16_t __p)
+{
+ return vldrhq_z_f16 ( __base, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_f16 (float16_t * __addr, float16x8x2_t __value)
+{
+ union { float16x8x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv8hf (__addr, __rv.__o);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_f16 (float16_t * __addr, float16x8_t __value, mve_pred16_t __p)
+{
+ return vstrhq_p_f16 (__addr, __value, __p);
+}
+
+__extension__ extern __inline float32x4x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld4q_f32 (float32_t const * __addr)
+{
+ union { float32x4x4_t __i; __builtin_neon_xi __o; } __rv;
+ __rv.__o = __builtin_mve_vld4qv4sf (__addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline float32x4x2_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld2q_f32 (float32_t const * __addr)
+{
+ union { float32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__o = __builtin_mve_vld2qv4sf (__addr);
+ return __rv.__i;
+}
+
+__extension__ extern __inline float32x4_t
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vld1q_z_f32 (float32_t const *__base, mve_pred16_t __p)
+{
+ return vldrwq_z_f32 ( __base, __p);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst2q_f32 (float32_t * __addr, float32x4x2_t __value)
+{
+ union { float32x4x2_t __i; __builtin_neon_oi __o; } __rv;
+ __rv.__i = __value;
+ __builtin_mve_vst2qv4sf (__addr, __rv.__o);
+}
+
+__extension__ extern __inline void
+__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
+__arm_vst1q_p_f32 (float32_t * __addr, float32x4_t __value, mve_pred16_t __p)
+{
+ return vstrwq_p_f32 (__addr, __value, __p);
+}
+
#endif
enum {
@@ -21911,6 +22279,42 @@ extern void *__ARM_undef;
int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld1q_f16 (__ARM_mve_coerce(__p0, float16_t const *)), \
int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld1q_f32 (__ARM_mve_coerce(__p0, float32_t const *)));})
+#define vld1q_z(p0,p1) __arm_vld1q_z(p0, p1)
+#define __arm_vld1q_z(p0,p1) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld1q_z_s8 (__ARM_mve_coerce(__p0, int8_t const *), p1), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld1q_z_s16 (__ARM_mve_coerce(__p0, int16_t const *), p1), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld1q_z_s32 (__ARM_mve_coerce(__p0, int32_t const *), p1), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld1q_z_u8 (__ARM_mve_coerce(__p0, uint8_t const *), p1), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld1q_z_u16 (__ARM_mve_coerce(__p0, uint16_t const *), p1), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld1q_z_u32 (__ARM_mve_coerce(__p0, uint32_t const *), p1), \
+ int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld1q_z_f16 (__ARM_mve_coerce(__p0, float16_t const *), p1), \
+ int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld1q_z_f32 (__ARM_mve_coerce(__p0, float32_t const *), p1));})
+
+#define vld2q(p0) __arm_vld2q(p0)
+#define __arm_vld2q(p0) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld2q_s8 (__ARM_mve_coerce(__p0, int8_t const *)), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld2q_s16 (__ARM_mve_coerce(__p0, int16_t const *)), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld2q_s32 (__ARM_mve_coerce(__p0, int32_t const *)), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld2q_u8 (__ARM_mve_coerce(__p0, uint8_t const *)), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld2q_u16 (__ARM_mve_coerce(__p0, uint16_t const *)), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld2q_u32 (__ARM_mve_coerce(__p0, uint32_t const *)), \
+ int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld2q_f16 (__ARM_mve_coerce(__p0, float16_t const *)), \
+ int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld2q_f32 (__ARM_mve_coerce(__p0, float32_t const *)));})
+
+#define vld4q(p0) __arm_vld4q(p0)
+#define __arm_vld4q(p0) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld4q_s8 (__ARM_mve_coerce(__p0, int8_t const *)), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld4q_s16 (__ARM_mve_coerce(__p0, int16_t const *)), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld4q_s32 (__ARM_mve_coerce(__p0, int32_t const *)), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld4q_u8 (__ARM_mve_coerce(__p0, uint8_t const *)), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld4q_u16 (__ARM_mve_coerce(__p0, uint16_t const *)), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld4q_u32 (__ARM_mve_coerce(__p0, uint32_t const *)), \
+ int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld4q_f16 (__ARM_mve_coerce(__p0, float16_t const *)), \
+ int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld4q_f32 (__ARM_mve_coerce(__p0, float32_t const *)));})
+
#define vldrhq_gather_offset(p0,p1) __arm_vldrhq_gather_offset(p0,p1)
#define __arm_vldrhq_gather_offset(p0,p1) ({ __typeof(p0) __p0 = (p0); \
__typeof(p1) __p1 = (p1); \
@@ -21979,6 +22383,32 @@ extern void *__ARM_undef;
int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vldrwq_gather_shifted_offset_z_u32 (__ARM_mve_coerce(__p0, uint32_t const *), p1, p2), \
int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vldrwq_gather_shifted_offset_z_f32 (__ARM_mve_coerce(__p0, float32_t const *), p1, p2));})
+#define vst1q_p(p0,p1,p2) __arm_vst1q_p(p0,p1,p2)
+#define __arm_vst1q_p(p0,p1,p2) ({ __typeof(p0) __p0 = (p0); \
+ __typeof(p1) __p1 = (p1); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
+ int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16_t]: __arm_vst1q_p_s8 (__ARM_mve_coerce(__p0, int8_t *), __ARM_mve_coerce(__p1, int8x16_t), p2), \
+ int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8_t]: __arm_vst1q_p_s16 (__ARM_mve_coerce(__p0, int16_t *), __ARM_mve_coerce(__p1, int16x8_t), p2), \
+ int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4_t]: __arm_vst1q_p_s32 (__ARM_mve_coerce(__p0, int32_t *), __ARM_mve_coerce(__p1, int32x4_t), p2), \
+ int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16_t]: __arm_vst1q_p_u8 (__ARM_mve_coerce(__p0, uint8_t *), __ARM_mve_coerce(__p1, uint8x16_t), p2), \
+ int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]: __arm_vst1q_p_u16 (__ARM_mve_coerce(__p0, uint16_t *), __ARM_mve_coerce(__p1, uint16x8_t), p2), \
+ int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]: __arm_vst1q_p_u32 (__ARM_mve_coerce(__p0, uint32_t *), __ARM_mve_coerce(__p1, uint32x4_t), p2), \
+ int (*)[__ARM_mve_type_float16_t_ptr][__ARM_mve_type_float16x8_t]: __arm_vst1q_p_f16 (__ARM_mve_coerce(__p0, float16_t *), __ARM_mve_coerce(__p1, float16x8_t), p2), \
+ int (*)[__ARM_mve_type_float32_t_ptr][__ARM_mve_type_float32x4_t]: __arm_vst1q_p_f32 (__ARM_mve_coerce(__p0, float32_t *), __ARM_mve_coerce(__p1, float32x4_t), p2));})
+
+#define vst2q(p0,p1) __arm_vst2q(p0,p1)
+#define __arm_vst2q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
+ __typeof(p1) __p1 = (p1); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
+ int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16x2_t]: __arm_vst2q_s8 (__ARM_mve_coerce(__p0, int8_t *), __ARM_mve_coerce(__p1, int8x16x2_t)), \
+ int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8x2_t]: __arm_vst2q_s16 (__ARM_mve_coerce(__p0, int16_t *), __ARM_mve_coerce(__p1, int16x8x2_t)), \
+ int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4x2_t]: __arm_vst2q_s32 (__ARM_mve_coerce(__p0, int32_t *), __ARM_mve_coerce(__p1, int32x4x2_t)), \
+ int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16x2_t]: __arm_vst2q_u8 (__ARM_mve_coerce(__p0, uint8_t *), __ARM_mve_coerce(__p1, uint8x16x2_t)), \
+ int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8x2_t]: __arm_vst2q_u16 (__ARM_mve_coerce(__p0, uint16_t *), __ARM_mve_coerce(__p1, uint16x8x2_t)), \
+ int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4x2_t]: __arm_vst2q_u32 (__ARM_mve_coerce(__p0, uint32_t *), __ARM_mve_coerce(__p1, uint32x4x2_t)), \
+ int (*)[__ARM_mve_type_float16_t_ptr][__ARM_mve_type_float16x8x2_t]: __arm_vst2q_f16 (__ARM_mve_coerce(__p0, float16_t *), __ARM_mve_coerce(__p1, float16x8x2_t)), \
+ int (*)[__ARM_mve_type_float32_t_ptr][__ARM_mve_type_float32x4x2_t]: __arm_vst2q_f32 (__ARM_mve_coerce(__p0, float32_t *), __ARM_mve_coerce(__p1, float32x4x2_t)));})
+
#define vst1q(p0,p1) __arm_vst1q(p0,p1)
#define __arm_vst1q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
__typeof(p1) __p1 = (p1); \
@@ -24849,6 +25279,28 @@ extern void *__ARM_undef;
int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]: __arm_vst1q_u16 (__ARM_mve_coerce(__p0, uint16_t *), __ARM_mve_coerce(__p1, uint16x8_t)), \
int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]: __arm_vst1q_u32 (__ARM_mve_coerce(__p0, uint32_t *), __ARM_mve_coerce(__p1, uint32x4_t)));})
+#define vst1q_p(p0,p1,p2) __arm_vst1q_p(p0,p1,p2)
+#define __arm_vst1q_p(p0,p1,p2) ({ __typeof(p0) __p0 = (p0); \
+ __typeof(p1) __p1 = (p1); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
+ int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16_t]: __arm_vst1q_p_s8 (__ARM_mve_coerce(__p0, int8_t *), __ARM_mve_coerce(__p1, int8x16_t), p2), \
+ int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8_t]: __arm_vst1q_p_s16 (__ARM_mve_coerce(__p0, int16_t *), __ARM_mve_coerce(__p1, int16x8_t), p2), \
+ int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4_t]: __arm_vst1q_p_s32 (__ARM_mve_coerce(__p0, int32_t *), __ARM_mve_coerce(__p1, int32x4_t), p2), \
+ int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16_t]: __arm_vst1q_p_u8 (__ARM_mve_coerce(__p0, uint8_t *), __ARM_mve_coerce(__p1, uint8x16_t), p2), \
+ int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]: __arm_vst1q_p_u16 (__ARM_mve_coerce(__p0, uint16_t *), __ARM_mve_coerce(__p1, uint16x8_t), p2), \
+ int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]: __arm_vst1q_p_u32 (__ARM_mve_coerce(__p0, uint32_t *), __ARM_mve_coerce(__p1, uint32x4_t), p2));})
+
+#define vst2q(p0,p1) __arm_vst2q(p0,p1)
+#define __arm_vst2q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
+ __typeof(p1) __p1 = (p1); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
+ int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16x2_t]: __arm_vst2q_s8 (__ARM_mve_coerce(__p0, int8_t *), __ARM_mve_coerce(__p1, int8x16x2_t)), \
+ int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8x2_t]: __arm_vst2q_s16 (__ARM_mve_coerce(__p0, int16_t *), __ARM_mve_coerce(__p1, int16x8x2_t)), \
+ int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4x2_t]: __arm_vst2q_s32 (__ARM_mve_coerce(__p0, int32_t *), __ARM_mve_coerce(__p1, int32x4x2_t)), \
+ int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16x2_t]: __arm_vst2q_u8 (__ARM_mve_coerce(__p0, uint8_t *), __ARM_mve_coerce(__p1, uint8x16x2_t)), \
+ int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8x2_t]: __arm_vst2q_u16 (__ARM_mve_coerce(__p0, uint16_t *), __ARM_mve_coerce(__p1, uint16x8x2_t)), \
+ int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4x2_t]: __arm_vst2q_u32 (__ARM_mve_coerce(__p0, uint32_t *), __ARM_mve_coerce(__p1, uint32x4x2_t)));})
+
#define vstrhq(p0,p1) __arm_vstrhq(p0,p1)
#define __arm_vstrhq(p0,p1) ({ __typeof(p0) __p0 = (p0); \
__typeof(p1) __p1 = (p1); \
@@ -25403,6 +25855,36 @@ extern void *__ARM_undef;
int (*)[__ARM_mve_type_uint16x8_t]: __arm_vbrsrq_x_n_u16 (__ARM_mve_coerce(__p1, uint16x8_t), p2, p3), \
int (*)[__ARM_mve_type_uint32x4_t]: __arm_vbrsrq_x_n_u32 (__ARM_mve_coerce(__p1, uint32x4_t), p2, p3));})
+#define vld1q_z(p0,p1) __arm_vld1q_z(p0, p1)
+#define __arm_vld1q_z(p0,p1) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld1q_z_s8 (__ARM_mve_coerce(__p0, int8_t const *), p1), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld1q_z_s16 (__ARM_mve_coerce(__p0, int16_t const *), p1), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld1q_z_s32 (__ARM_mve_coerce(__p0, int32_t const *), p1), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld1q_z_u8 (__ARM_mve_coerce(__p0, uint8_t const *), p1), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld1q_z_u16 (__ARM_mve_coerce(__p0, uint16_t const *), p1), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld1q_z_u32 (__ARM_mve_coerce(__p0, uint32_t const *), p1));})
+
+#define vld2q(p0) __arm_vld2q(p0)
+#define __arm_vld2q(p0) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld2q_s8 (__ARM_mve_coerce(__p0, int8_t const *)), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld2q_s16 (__ARM_mve_coerce(__p0, int16_t const *)), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld2q_s32 (__ARM_mve_coerce(__p0, int32_t const *)), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld2q_u8 (__ARM_mve_coerce(__p0, uint8_t const *)), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld2q_u16 (__ARM_mve_coerce(__p0, uint16_t const *)), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld2q_u32 (__ARM_mve_coerce(__p0, uint32_t const *)));})
+
+#define vld4q(p0) __arm_vld4q(p0)
+#define __arm_vld4q(p0) ({ __typeof(p0) __p0 = (p0); \
+ _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
+ int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld4q_s8 (__ARM_mve_coerce(__p0, int8_t const *)), \
+ int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld4q_s16 (__ARM_mve_coerce(__p0, int16_t const *)), \
+ int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld4q_s32 (__ARM_mve_coerce(__p0, int32_t const *)), \
+ int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld4q_u8 (__ARM_mve_coerce(__p0, uint8_t const *)), \
+ int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld4q_u16 (__ARM_mve_coerce(__p0, uint16_t const *)), \
+ int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld4q_u32 (__ARM_mve_coerce(__p0, uint32_t const *)));})
+
#endif /* MVE Integer. */
#define vmvnq_x(p1,p2) __arm_vmvnq_x(p1,p2)
diff --git a/gcc/config/arm/arm_mve_builtins.def b/gcc/config/arm/arm_mve_builtins.def
index 38f46beb76a3068dcb8dd97e3ee8dbe2707dd72e..a60650cb7b1fe4e52ab1c7bf3c1215ff083a106f 100644
--- a/gcc/config/arm/arm_mve_builtins.def
+++ b/gcc/config/arm/arm_mve_builtins.def
@@ -873,3 +873,6 @@ VAR1 (QUADOP_NONE_NONE_NONE_NONE_UNONE, vsbciq_m_s, v4si)
VAR1 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE, vsbciq_m_u, v4si)
VAR1 (QUADOP_NONE_NONE_NONE_NONE_UNONE, vsbcq_m_s, v4si)
VAR1 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE, vsbcq_m_u, v4si)
+VAR5 (STORE1, vst2q, v16qi, v8hi, v4si, v8hf, v4sf)
+VAR5 (LOAD1, vld4q, v16qi, v8hi, v4si, v8hf, v4sf)
+VAR5 (LOAD1, vld2q, v16qi, v8hi, v4si, v8hf, v4sf)
diff --git a/gcc/config/arm/mve.md b/gcc/config/arm/mve.md
index 25b59732d257a19f38ff7e54898df5cef4fdef3d..2e28d9d8408127dd52b9d16c772e7f27a47d390a 100644
--- a/gcc/config/arm/mve.md
+++ b/gcc/config/arm/mve.md
@@ -214,7 +214,7 @@
VLDRDQGBWB_S VLDRDQGBWB_U VADCQ_U VADCQ_M_U VADCQ_S
VADCQ_M_S VSBCIQ_U VSBCIQ_S VSBCIQ_M_U VSBCIQ_M_S
VSBCQ_U VSBCQ_S VSBCQ_M_U VSBCQ_M_S VADCIQ_U VADCIQ_M_U
- VADCIQ_S VADCIQ_M_S])
+ VADCIQ_S VADCIQ_M_S VLD2Q VLD4Q VST2Q])
(define_mode_attr MVE_CNVT [(V8HI "V8HF") (V4SI "V4SF") (V8HF "V8HI")
(V4SF "V4SI")])
@@ -10797,3 +10797,91 @@
"vsbc.i32\t%q0, %q1, %q2"
[(set_attr "type" "mve_move")
(set_attr "length" "4")])
+
+;;
+;; [vst2q])
+;;
+(define_insn "mve_vst2q<mode>"
+ [(set (match_operand:OI 0 "neon_struct_operand" "=Um")
+ (unspec:OI [(match_operand:OI 1 "s_register_operand" "w")
+ (unspec:MVE_VLD_ST [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
+ VST2Q))
+ ]
+ "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
+ || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE (<MODE>mode))"
+{
+ rtx ops[4];
+ int regno = REGNO (operands[1]);
+ ops[0] = gen_rtx_REG (TImode, regno);
+ ops[1] = gen_rtx_REG (TImode, regno + 4);
+ rtx reg = operands[0];
+ while (reg && !REG_P (reg))
+ reg = XEXP (reg, 0);
+ gcc_assert (REG_P (reg));
+ ops[2] = reg;
+ ops[3] = operands[0];
+ output_asm_insn ("vst20.<V_sz_elem>\t{%q0, %q1}, [%2]\n\t"
+ "vst21.<V_sz_elem>\t{%q0, %q1}, %3", ops);
+ return "";
+}
+ [(set_attr "length" "8")])
+
+;;
+;; [vld2q])
+;;
+(define_insn "mve_vld2q<mode>"
+ [(set (match_operand:OI 0 "s_register_operand" "=w")
+ (unspec:OI [(match_operand:OI 1 "neon_struct_operand" "Um")
+ (unspec:MVE_VLD_ST [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
+ VLD2Q))
+ ]
+ "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
+ || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE (<MODE>mode))"
+{
+ rtx ops[4];
+ int regno = REGNO (operands[0]);
+ ops[0] = gen_rtx_REG (TImode, regno);
+ ops[1] = gen_rtx_REG (TImode, regno + 4);
+ rtx reg = operands[1];
+ while (reg && !REG_P (reg))
+ reg = XEXP (reg, 0);
+ gcc_assert (REG_P (reg));
+ ops[2] = reg;
+ ops[3] = operands[1];
+ output_asm_insn ("vld20.<V_sz_elem>\t{%q0, %q1}, [%2]\n\t"
+ "vld21.<V_sz_elem>\t{%q0, %q1}, %3", ops);
+ return "";
+}
+ [(set_attr "length" "8")])
+
+;;
+;; [vld4q])
+;;
+(define_insn "mve_vld4q<mode>"
+ [(set (match_operand:XI 0 "s_register_operand" "=w")
+ (unspec:XI [(match_operand:XI 1 "neon_struct_operand" "Um")
+ (unspec:MVE_VLD_ST [(const_int 0)] UNSPEC_VSTRUCTDUMMY)]
+ VLD4Q))
+ ]
+ "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
+ || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE (<MODE>mode))"
+{
+ rtx ops[6];
+ int regno = REGNO (operands[0]);
+ ops[0] = gen_rtx_REG (TImode, regno);
+ ops[1] = gen_rtx_REG (TImode, regno+4);
+ ops[2] = gen_rtx_REG (TImode, regno+8);
+ ops[3] = gen_rtx_REG (TImode, regno + 12);
+ rtx reg = operands[1];
+ while (reg && !REG_P (reg))
+ reg = XEXP (reg, 0);
+ gcc_assert (REG_P (reg));
+ ops[4] = reg;
+ ops[5] = operands[1];
+ output_asm_insn ("vld40.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
+ "vld41.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
+ "vld42.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
+ "vld43.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, %5", ops);
+ return "";
+}
+ [(set_attr "length" "16")])
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c
new file mode 100644
index 0000000000000000000000000000000000000000..830d817d14353645c4b647069cc37cb61b28d6c2
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float16x8_t
+foo (float16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_f16 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.f16" } } */
+
+float16x8_t
+foo1 (float16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.f16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c
new file mode 100644
index 0000000000000000000000000000000000000000..84f976a6605949cf4ce565dfb426ea9e57d775db
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float32x4_t
+foo (float32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_f32 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.f32" } } */
+
+float32x4_t
+foo1 (float32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.f32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c
new file mode 100644
index 0000000000000000000000000000000000000000..8bb7ef34d69ed9827d0d3a2576457883ed6be30b
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int16x8_t
+foo (int16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_s16 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.s16" } } */
+
+int16x8_t
+foo1 (int16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.s16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c
new file mode 100644
index 0000000000000000000000000000000000000000..f5d7cc0396f0dbb55b463b4919cb4ad84ce01f6d
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int32x4_t
+foo (int32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_s32 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.s32" } } */
+
+int32x4_t
+foo1 (int32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.s32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c
new file mode 100644
index 0000000000000000000000000000000000000000..a3999e680277ce3e0e00e5e4a826df9a31dfa714
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int8x16_t
+foo (int8_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_s8 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrbt.s8" } } */
+
+int8x16_t
+foo1 (int8_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrbt.s8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c
new file mode 100644
index 0000000000000000000000000000000000000000..ada9c2ff1aacae47811d8b12b6f70f2085722bdf
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint16x8_t
+foo (uint16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_u16 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.u16" } } */
+
+uint16x8_t
+foo1 (uint16_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrht.u16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c
new file mode 100644
index 0000000000000000000000000000000000000000..c96be7b76c2b6158e36a7bba0e41b0bb94363050
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint32x4_t
+foo (uint32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_u32 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.u32" } } */
+
+uint32x4_t
+foo1 (uint32_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrwt.u32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c
new file mode 100644
index 0000000000000000000000000000000000000000..faca38dd99584b05e8d9c3d3bdb376e6cd0ecadf
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint8x16_t
+foo (uint8_t const * base, mve_pred16_t p)
+{
+ return vld1q_z_u8 (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrbt.u8" } } */
+
+uint8x16_t
+foo1 (uint8_t const * base, mve_pred16_t p)
+{
+ return vld1q_z (base, p);
+}
+
+/* { dg-final { scan-assembler "vldrbt.u8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c
new file mode 100644
index 0000000000000000000000000000000000000000..cb2bc6f9c4dda8777ea91171e3aa178a9c5528ed
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float16x8x2_t
+foo (float16_t const * addr)
+{
+ return vld2q_f16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
+/* { dg-final { scan-assembler "vld21.16" } } */
+
+float16x8x2_t
+foo1 (float16_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c
new file mode 100644
index 0000000000000000000000000000000000000000..f701d3d4cbcd992dda9abadfbcc7e222eb7a6fad
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float32x4x2_t
+foo (float32_t const * addr)
+{
+ return vld2q_f32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
+/* { dg-final { scan-assembler "vld21.32" } } */
+
+float32x4x2_t
+foo1 (float32_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c
new file mode 100644
index 0000000000000000000000000000000000000000..85e844cea441ea08b47d8ffba59aa2a8c59a7b2a
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int16x8x2_t
+foo (int16_t const * addr)
+{
+ return vld2q_s16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
+/* { dg-final { scan-assembler "vld21.16" } } */
+
+int16x8x2_t
+foo1 (int16_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c
new file mode 100644
index 0000000000000000000000000000000000000000..f46a9d17fe987de4174f6464a79db6598094166e
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int32x4x2_t
+foo (int32_t const * addr)
+{
+ return vld2q_s32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
+/* { dg-final { scan-assembler "vld21.32" } } */
+
+int32x4x2_t
+foo1 (int32_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c
new file mode 100644
index 0000000000000000000000000000000000000000..29dc2885f1231bb82619380d70a9d51164494642
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int8x16x2_t
+foo (int8_t const * addr)
+{
+ return vld2q_s8 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.8" } } */
+/* { dg-final { scan-assembler "vld21.8" } } */
+
+int8x16x2_t
+foo1 (int8_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c
new file mode 100644
index 0000000000000000000000000000000000000000..7d867b5b7a4ac980c132c438f6b2d810c938d502
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint16x8x2_t
+foo (uint16_t const * addr)
+{
+ return vld2q_u16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
+/* { dg-final { scan-assembler "vld21.16" } } */
+
+uint16x8x2_t
+foo1 (uint16_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c
new file mode 100644
index 0000000000000000000000000000000000000000..6c9d12e9cd8e0061f75e24ef6a4d822a4c394a66
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint32x4x2_t
+foo (uint32_t const * addr)
+{
+ return vld2q_u32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
+/* { dg-final { scan-assembler "vld21.32" } } */
+
+uint32x4x2_t
+foo1 (uint32_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c
new file mode 100644
index 0000000000000000000000000000000000000000..002a645342748373fa010b5d6e89d40ad5aa192a
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint8x16x2_t
+foo (uint8_t const * addr)
+{
+ return vld2q_u8 (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.8" } } */
+/* { dg-final { scan-assembler "vld21.8" } } */
+
+uint8x16x2_t
+foo1 (uint8_t const * addr)
+{
+ return vld2q (addr);
+}
+
+/* { dg-final { scan-assembler "vld20.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c
new file mode 100644
index 0000000000000000000000000000000000000000..386b71b35258eab2031d62d49cb5578f22e0557b
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float16x8x4_t
+foo (float16_t const * addr)
+{
+ return vld4q_f16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
+/* { dg-final { scan-assembler "vld41.16" } } */
+/* { dg-final { scan-assembler "vld42.16" } } */
+/* { dg-final { scan-assembler "vld43.16" } } */
+
+float16x8x4_t
+foo1 (float16_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c
new file mode 100644
index 0000000000000000000000000000000000000000..c38bb54a4ca11689a1f7754707561b3e4eee0426
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+float32x4x4_t
+foo (float32_t const * addr)
+{
+ return vld4q_f32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
+/* { dg-final { scan-assembler "vld41.32" } } */
+/* { dg-final { scan-assembler "vld42.32" } } */
+/* { dg-final { scan-assembler "vld43.32" } } */
+
+float32x4x4_t
+foo1 (float32_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c
new file mode 100644
index 0000000000000000000000000000000000000000..68e6b98fec298cf07c4d0b97bbe063ea34c4c8ac
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int16x8x4_t
+foo (int16_t const * addr)
+{
+ return vld4q_s16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
+/* { dg-final { scan-assembler "vld41.16" } } */
+/* { dg-final { scan-assembler "vld42.16" } } */
+/* { dg-final { scan-assembler "vld43.16" } } */
+
+int16x8x4_t
+foo1 (int16_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c
new file mode 100644
index 0000000000000000000000000000000000000000..db0ba20bfb193b2cf2d59f940bb1595799cc428e
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int32x4x4_t
+foo (int32_t const * addr)
+{
+ return vld4q_s32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
+/* { dg-final { scan-assembler "vld41.32" } } */
+/* { dg-final { scan-assembler "vld42.32" } } */
+/* { dg-final { scan-assembler "vld43.32" } } */
+
+int32x4x4_t
+foo1 (int32_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c
new file mode 100644
index 0000000000000000000000000000000000000000..e38bdeab87bd19eaf0e933c7551a84130e3afd97
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+int8x16x4_t
+foo (int8_t const * addr)
+{
+ return vld4q_s8 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.8" } } */
+/* { dg-final { scan-assembler "vld41.8" } } */
+/* { dg-final { scan-assembler "vld42.8" } } */
+/* { dg-final { scan-assembler "vld43.8" } } */
+
+int8x16x4_t
+foo1 (int8_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c
new file mode 100644
index 0000000000000000000000000000000000000000..7f6a7838fc0889db889e800b2380287908f5d8b9
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint16x8x4_t
+foo (uint16_t const * addr)
+{
+ return vld4q_u16 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
+/* { dg-final { scan-assembler "vld41.16" } } */
+/* { dg-final { scan-assembler "vld42.16" } } */
+/* { dg-final { scan-assembler "vld43.16" } } */
+
+uint16x8x4_t
+foo1 (uint16_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c
new file mode 100644
index 0000000000000000000000000000000000000000..29af573735335d1d86141daf259d622a6e84f338
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint32x4x4_t
+foo (uint32_t const * addr)
+{
+ return vld4q_u32 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
+/* { dg-final { scan-assembler "vld41.32" } } */
+/* { dg-final { scan-assembler "vld42.32" } } */
+/* { dg-final { scan-assembler "vld43.32" } } */
+
+uint32x4x4_t
+foo1 (uint32_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c
new file mode 100644
index 0000000000000000000000000000000000000000..f54036229c60ab55cafd4fc5eae5d584b3e50a6c
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c
@@ -0,0 +1,25 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+uint8x16x4_t
+foo (uint8_t const * addr)
+{
+ return vld4q_u8 (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.8" } } */
+/* { dg-final { scan-assembler "vld41.8" } } */
+/* { dg-final { scan-assembler "vld42.8" } } */
+/* { dg-final { scan-assembler "vld43.8" } } */
+
+uint8x16x4_t
+foo1 (uint8_t const * addr)
+{
+ return vld4q (addr);
+}
+
+/* { dg-final { scan-assembler "vld40.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c
new file mode 100644
index 0000000000000000000000000000000000000000..7ef5ccee663c609c2d8f5ceecca3e115f697d955
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (float16_t * addr, float16x8_t value, mve_pred16_t p)
+{
+ vst1q_p_f16 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
+
+void
+foo1 (float16_t * addr, float16x8_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c
new file mode 100644
index 0000000000000000000000000000000000000000..2cd7221985a663703e5a4c2a3ae266079b68c007
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (float32_t * addr, float32x4_t value, mve_pred16_t p)
+{
+ vst1q_p_f32 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
+
+void
+foo1 (float32_t * addr, float32x4_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c
new file mode 100644
index 0000000000000000000000000000000000000000..ca56f7384aca4898542851706cfed60255c281e1
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int16_t * addr, int16x8_t value, mve_pred16_t p)
+{
+ vst1q_p_s16 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
+
+void
+foo1 (int16_t * addr, int16x8_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c
new file mode 100644
index 0000000000000000000000000000000000000000..782496f458967f3f0489350a91701ca0e4a943e8
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int32_t * addr, int32x4_t value, mve_pred16_t p)
+{
+ vst1q_p_s32 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
+
+void
+foo1 (int32_t * addr, int32x4_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c
new file mode 100644
index 0000000000000000000000000000000000000000..92bbc0a239a0a3dcc92f06655a8dfe43f11d603c
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int8_t * addr, int8x16_t value, mve_pred16_t p)
+{
+ vst1q_p_s8 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrbt.8" } } */
+
+void
+foo1 (int8_t * addr, int8x16_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrbt.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c
new file mode 100644
index 0000000000000000000000000000000000000000..12c50f7b137a49e7f1f78df612830e7dfeb4ffbd
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint16_t * addr, uint16x8_t value, mve_pred16_t p)
+{
+ vst1q_p_u16 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
+
+void
+foo1 (uint16_t * addr, uint16x8_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrht.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c
new file mode 100644
index 0000000000000000000000000000000000000000..2f7ef61aaaef135644c611c3efb2e3fadd0c38a7
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint32_t * addr, uint32x4_t value, mve_pred16_t p)
+{
+ vst1q_p_u32 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
+
+void
+foo1 (uint32_t * addr, uint32x4_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrwt.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c
new file mode 100644
index 0000000000000000000000000000000000000000..56fde60c54b380e89a62ac013e828298b788a288
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c
@@ -0,0 +1,22 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint8_t * addr, uint8x16_t value, mve_pred16_t p)
+{
+ vst1q_p_u8 (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrbt.8" } } */
+
+void
+foo1 (uint8_t * addr, uint8x16_t value, mve_pred16_t p)
+{
+ vst1q_p (addr, value, p);
+}
+
+/* { dg-final { scan-assembler "vstrbt.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c
new file mode 100644
index 0000000000000000000000000000000000000000..79e1b5c035526dcf70a7c165817198869ee4060d
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (float16_t * addr, float16x8x2_t value)
+{
+ vst2q_f16 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
+/* { dg-final { scan-assembler "vst21.16" } } */
+
+void
+foo1 (float16_t * addr, float16x8x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c
new file mode 100644
index 0000000000000000000000000000000000000000..7d256aacd33d1d7dbc4c47c7612499eb427cf27f
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
+/* { dg-add-options arm_v8_1m_mve_fp } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (float32_t * addr, float32x4x2_t value)
+{
+ vst2q_f32 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
+/* { dg-final { scan-assembler "vst21.32" } } */
+
+void
+foo1 (float32_t * addr, float32x4x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c
new file mode 100644
index 0000000000000000000000000000000000000000..f2fd867b877a4b129a33e83d5b102be627449bd5
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int16_t * addr, int16x8x2_t value)
+{
+ vst2q_s16 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
+/* { dg-final { scan-assembler "vst21.16" } } */
+
+void
+foo1 (int16_t * addr, int16x8x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c
new file mode 100644
index 0000000000000000000000000000000000000000..85e36df48a339b4a658c56b1e0a156f89fd0a2b2
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int32_t * addr, int32x4x2_t value)
+{
+ vst2q_s32 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
+/* { dg-final { scan-assembler "vst21.32" } } */
+
+void
+foo1 (int32_t * addr, int32x4x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c
new file mode 100644
index 0000000000000000000000000000000000000000..57e9efc44f16cb4db6317d17bf38edd06e0ea78a
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (int8_t * addr, int8x16x2_t value)
+{
+ vst2q_s8 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.8" } } */
+/* { dg-final { scan-assembler "vst21.8" } } */
+
+void
+foo1 (int8_t * addr, int8x16x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.8" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c
new file mode 100644
index 0000000000000000000000000000000000000000..b54c79157b20bde98cb505fa4291049560676ed0
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint16_t * addr, uint16x8x2_t value)
+{
+ vst2q_u16 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
+/* { dg-final { scan-assembler "vst21.16" } } */
+
+void
+foo1 (uint16_t * addr, uint16x8x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.16" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c
new file mode 100644
index 0000000000000000000000000000000000000000..167f8bdb14e418e888a58ab0ca157abac1484549
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint32_t * addr, uint32x4x2_t value)
+{
+ vst2q_u32 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
+/* { dg-final { scan-assembler "vst21.32" } } */
+
+void
+foo1 (uint32_t * addr, uint32x4x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.32" } } */
diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c
new file mode 100644
index 0000000000000000000000000000000000000000..9f7a5f1a7c00fc6a17e46935ca0b174cbfca8979
--- /dev/null
+++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c
@@ -0,0 +1,23 @@
+/* { dg-do compile } */
+/* { dg-require-effective-target arm_v8_1m_mve_ok } */
+/* { dg-add-options arm_v8_1m_mve } */
+/* { dg-additional-options "-O2" } */
+
+#include "arm_mve.h"
+
+void
+foo (uint8_t * addr, uint8x16x2_t value)
+{
+ vst2q_u8 (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.8" } } */
+/* { dg-final { scan-assembler "vst21.8" } } */
+
+void
+foo1 (uint8_t * addr, uint8x16x2_t value)
+{
+ vst2q (addr, value);
+}
+
+/* { dg-final { scan-assembler "vst20.8" } } */
[-- Attachment #2: rb12714.patch.gz --]
[-- Type: application/gzip, Size: 6396 bytes --]
^ permalink raw reply [flat|nested] 2+ messages in thread
* RE: [PATCH v2][ARM][GCC][11x]: MVE ACLE vector interleaving store and deinterleaving load intrinsics and also aliases to vstr and vldr intrinsics.
2020-03-20 16:42 [PATCH v2][ARM][GCC][11x]: MVE ACLE vector interleaving store and deinterleaving load intrinsics and also aliases to vstr and vldr intrinsics Srinath Parvathaneni
@ 2020-03-20 16:58 ` Kyrylo Tkachov
0 siblings, 0 replies; 2+ messages in thread
From: Kyrylo Tkachov @ 2020-03-20 16:58 UTC (permalink / raw)
To: Srinath Parvathaneni, gcc-patches
Hi Srinath,
> -----Original Message-----
> From: Srinath Parvathaneni <Srinath.Parvathaneni@arm.com>
> Sent: 20 March 2020 16:42
> To: gcc-patches@gcc.gnu.org
> Cc: Kyrylo Tkachov <Kyrylo.Tkachov@arm.com>
> Subject: [PATCH v2][ARM][GCC][11x]: MVE ACLE vector interleaving store and
> deinterleaving load intrinsics and also aliases to vstr and vldr intrinsics.
>
> Hello Kyrill,
>
> Following patch is the rebased version of v1.
> (version v1) https://gcc.gnu.org/pipermail/gcc-patches/2019-
> November/534347.html
>
> ####
>
> Hello,
>
> This patch supports following MVE ACLE intrinsics which are aliases of vstr
> and
> vldr intrinsics.
>
> vst1q_p_u8, vst1q_p_s8, vld1q_z_u8, vld1q_z_s8, vst1q_p_u16, vst1q_p_s16,
> vld1q_z_u16, vld1q_z_s16, vst1q_p_u32, vst1q_p_s32, vld1q_z_u32,
> vld1q_z_s32,
> vld1q_z_f16, vst1q_p_f16, vld1q_z_f32, vst1q_p_f32.
>
> This patch also supports following MVE ACLE vector deinterleaving loads and
> vector
> interleaving stores.
>
> vst2q_s8, vst2q_u8, vld2q_s8, vld2q_u8, vld4q_s8, vld4q_u8, vst2q_s16,
> vst2q_u16,
> vld2q_s16, vld2q_u16, vld4q_s16, vld4q_u16, vst2q_s32, vst2q_u32,
> vld2q_s32,
> vld2q_u32, vld4q_s32, vld4q_u32, vld4q_f16, vld2q_f16, vst2q_f16,
> vld4q_f32,
> vld2q_f32, vst2q_f32.
>
> Please refer to M-profile Vector Extension (MVE) intrinsics [1] for more
> details.
> [1] https://developer.arm.com/architectures/instruction-sets/simd-
> isas/helium/mve-intrinsics
>
> Regression tested on arm-none-eabi and found no regressions.
>
> Ok for trunk?
Thanks, I've pushed this patch to master.
Kyrill
>
> Thanks,
> Srinath.
>
> gcc/ChangeLog:
>
> 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
> Andre Vieira <andre.simoesdiasvieira@arm.com>
> Mihail Ionescu <mihail.ionescu@arm.com>
>
> * config/arm/arm_mve.h (vst1q_p_u8): Define macro.
> (vst1q_p_s8): Likewise.
> (vst2q_s8): Likewise.
> (vst2q_u8): Likewise.
> (vld1q_z_u8): Likewise.
> (vld1q_z_s8): Likewise.
> (vld2q_s8): Likewise.
> (vld2q_u8): Likewise.
> (vld4q_s8): Likewise.
> (vld4q_u8): Likewise.
> (vst1q_p_u16): Likewise.
> (vst1q_p_s16): Likewise.
> (vst2q_s16): Likewise.
> (vst2q_u16): Likewise.
> (vld1q_z_u16): Likewise.
> (vld1q_z_s16): Likewise.
> (vld2q_s16): Likewise.
> (vld2q_u16): Likewise.
> (vld4q_s16): Likewise.
> (vld4q_u16): Likewise.
> (vst1q_p_u32): Likewise.
> (vst1q_p_s32): Likewise.
> (vst2q_s32): Likewise.
> (vst2q_u32): Likewise.
> (vld1q_z_u32): Likewise.
> (vld1q_z_s32): Likewise.
> (vld2q_s32): Likewise.
> (vld2q_u32): Likewise.
> (vld4q_s32): Likewise.
> (vld4q_u32): Likewise.
> (vld4q_f16): Likewise.
> (vld2q_f16): Likewise.
> (vld1q_z_f16): Likewise.
> (vst2q_f16): Likewise.
> (vst1q_p_f16): Likewise.
> (vld4q_f32): Likewise.
> (vld2q_f32): Likewise.
> (vld1q_z_f32): Likewise.
> (vst2q_f32): Likewise.
> (vst1q_p_f32): Likewise.
> (__arm_vst1q_p_u8): Define intrinsic.
> (__arm_vst1q_p_s8): Likewise.
> (__arm_vst2q_s8): Likewise.
> (__arm_vst2q_u8): Likewise.
> (__arm_vld1q_z_u8): Likewise.
> (__arm_vld1q_z_s8): Likewise.
> (__arm_vld2q_s8): Likewise.
> (__arm_vld2q_u8): Likewise.
> (__arm_vld4q_s8): Likewise.
> (__arm_vld4q_u8): Likewise.
> (__arm_vst1q_p_u16): Likewise.
> (__arm_vst1q_p_s16): Likewise.
> (__arm_vst2q_s16): Likewise.
> (__arm_vst2q_u16): Likewise.
> (__arm_vld1q_z_u16): Likewise.
> (__arm_vld1q_z_s16): Likewise.
> (__arm_vld2q_s16): Likewise.
> (__arm_vld2q_u16): Likewise.
> (__arm_vld4q_s16): Likewise.
> (__arm_vld4q_u16): Likewise.
> (__arm_vst1q_p_u32): Likewise.
> (__arm_vst1q_p_s32): Likewise.
> (__arm_vst2q_s32): Likewise.
> (__arm_vst2q_u32): Likewise.
> (__arm_vld1q_z_u32): Likewise.
> (__arm_vld1q_z_s32): Likewise.
> (__arm_vld2q_s32): Likewise.
> (__arm_vld2q_u32): Likewise.
> (__arm_vld4q_s32): Likewise.
> (__arm_vld4q_u32): Likewise.
> (__arm_vld4q_f16): Likewise.
> (__arm_vld2q_f16): Likewise.
> (__arm_vld1q_z_f16): Likewise.
> (__arm_vst2q_f16): Likewise.
> (__arm_vst1q_p_f16): Likewise.
> (__arm_vld4q_f32): Likewise.
> (__arm_vld2q_f32): Likewise.
> (__arm_vld1q_z_f32): Likewise.
> (__arm_vst2q_f32): Likewise.
> (__arm_vst1q_p_f32): Likewise.
> (vld1q_z): Define polymorphic variant.
> (vld2q): Likewise.
> (vld4q): Likewise.
> (vst1q_p): Likewise.
> (vst2q): Likewise.
> * config/arm/arm_mve_builtins.def (STORE1): Use builtin qualifier.
> (LOAD1): Likewise.
> * config/arm/mve.md (mve_vst2q<mode>): Define RTL pattern.
> (mve_vld2q<mode>): Likewise.
> (mve_vld4q<mode>): Likewise.
>
> gcc/testsuite/ChangeLog:
>
> 2020-03-20 Srinath Parvathaneni <srinath.parvathaneni@arm.com>
> Andre Vieira <andre.simoesdiasvieira@arm.com>
> Mihail Ionescu <mihail.ionescu@arm.com>
>
> * gcc.target/arm/mve/intrinsics/vld1q_z_f16.c: New test.
> * gcc.target/arm/mve/intrinsics/vld1q_z_f32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_s16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_s32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_s8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_u16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_u32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld1q_z_u8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_f16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_f32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_s16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_s32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_s8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_u16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_u32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld2q_u8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_f16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_f32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_s16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_s32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_s8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_u16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_u32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vld4q_u8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_f16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_f32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_s16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_s32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_s8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_u16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_u32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst1q_p_u8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_f16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_f32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_s16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_s32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_s8.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_u16.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_u32.c: Likewise.
> * gcc.target/arm/mve/intrinsics/vst2q_u8.c: Likewise.
>
>
> ############### Attachment also inlined for ease of reply
> ###############
>
>
> diff --git a/gcc/config/arm/arm_mve.h b/gcc/config/arm/arm_mve.h
> index
> 220319cffd711323e5f72ba49407f4237f70ebf3..f6810ddf4b735e1cd782a67c2
> d48bab8ddb75814 100644
> --- a/gcc/config/arm/arm_mve.h
> +++ b/gcc/config/arm/arm_mve.h
> @@ -2466,6 +2466,46 @@ typedef struct { uint8x16_t val[4]; } uint8x16x4_t;
> #define vsbcq_u32(__a, __b, __carry) __arm_vsbcq_u32(__a, __b, __carry)
> #define vsbcq_m_s32(__inactive, __a, __b, __carry, __p)
> __arm_vsbcq_m_s32(__inactive, __a, __b, __carry, __p)
> #define vsbcq_m_u32(__inactive, __a, __b, __carry, __p)
> __arm_vsbcq_m_u32(__inactive, __a, __b, __carry, __p)
> +#define vst1q_p_u8(__addr, __value, __p) __arm_vst1q_p_u8(__addr,
> __value, __p)
> +#define vst1q_p_s8(__addr, __value, __p) __arm_vst1q_p_s8(__addr,
> __value, __p)
> +#define vst2q_s8(__addr, __value) __arm_vst2q_s8(__addr, __value)
> +#define vst2q_u8(__addr, __value) __arm_vst2q_u8(__addr, __value)
> +#define vld1q_z_u8(__base, __p) __arm_vld1q_z_u8(__base, __p)
> +#define vld1q_z_s8(__base, __p) __arm_vld1q_z_s8(__base, __p)
> +#define vld2q_s8(__addr) __arm_vld2q_s8(__addr)
> +#define vld2q_u8(__addr) __arm_vld2q_u8(__addr)
> +#define vld4q_s8(__addr) __arm_vld4q_s8(__addr)
> +#define vld4q_u8(__addr) __arm_vld4q_u8(__addr)
> +#define vst1q_p_u16(__addr, __value, __p) __arm_vst1q_p_u16(__addr,
> __value, __p)
> +#define vst1q_p_s16(__addr, __value, __p) __arm_vst1q_p_s16(__addr,
> __value, __p)
> +#define vst2q_s16(__addr, __value) __arm_vst2q_s16(__addr, __value)
> +#define vst2q_u16(__addr, __value) __arm_vst2q_u16(__addr, __value)
> +#define vld1q_z_u16(__base, __p) __arm_vld1q_z_u16(__base, __p)
> +#define vld1q_z_s16(__base, __p) __arm_vld1q_z_s16(__base, __p)
> +#define vld2q_s16(__addr) __arm_vld2q_s16(__addr)
> +#define vld2q_u16(__addr) __arm_vld2q_u16(__addr)
> +#define vld4q_s16(__addr) __arm_vld4q_s16(__addr)
> +#define vld4q_u16(__addr) __arm_vld4q_u16(__addr)
> +#define vst1q_p_u32(__addr, __value, __p) __arm_vst1q_p_u32(__addr,
> __value, __p)
> +#define vst1q_p_s32(__addr, __value, __p) __arm_vst1q_p_s32(__addr,
> __value, __p)
> +#define vst2q_s32(__addr, __value) __arm_vst2q_s32(__addr, __value)
> +#define vst2q_u32(__addr, __value) __arm_vst2q_u32(__addr, __value)
> +#define vld1q_z_u32(__base, __p) __arm_vld1q_z_u32(__base, __p)
> +#define vld1q_z_s32(__base, __p) __arm_vld1q_z_s32(__base, __p)
> +#define vld2q_s32(__addr) __arm_vld2q_s32(__addr)
> +#define vld2q_u32(__addr) __arm_vld2q_u32(__addr)
> +#define vld4q_s32(__addr) __arm_vld4q_s32(__addr)
> +#define vld4q_u32(__addr) __arm_vld4q_u32(__addr)
> +#define vld4q_f16(__addr) __arm_vld4q_f16(__addr)
> +#define vld2q_f16(__addr) __arm_vld2q_f16(__addr)
> +#define vld1q_z_f16(__base, __p) __arm_vld1q_z_f16(__base, __p)
> +#define vst2q_f16(__addr, __value) __arm_vst2q_f16(__addr, __value)
> +#define vst1q_p_f16(__addr, __value, __p) __arm_vst1q_p_f16(__addr,
> __value, __p)
> +#define vld4q_f32(__addr) __arm_vld4q_f32(__addr)
> +#define vld2q_f32(__addr) __arm_vld2q_f32(__addr)
> +#define vld1q_z_f32(__base, __p) __arm_vld1q_z_f32(__base, __p)
> +#define vst2q_f32(__addr, __value) __arm_vst2q_f32(__addr, __value)
> +#define vst1q_p_f32(__addr, __value, __p) __arm_vst1q_p_f32(__addr,
> __value, __p)
> #endif
>
> __extension__ extern __inline void
> @@ -16085,6 +16125,252 @@ __arm_vsbcq_m_u32 (uint32x4_t __inactive,
> uint32x4_t __a, uint32x4_t __b, unsign
> return __res;
> }
>
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_u8 (uint8_t * __addr, uint8x16_t __value, mve_pred16_t
> __p)
> +{
> + return vstrbq_p_u8 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_s8 (int8_t * __addr, int8x16_t __value, mve_pred16_t __p)
> +{
> + return vstrbq_p_s8 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_s8 (int8_t * __addr, int8x16x2_t __value)
> +{
> + union { int8x16x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv16qi ((__builtin_neon_qi *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_u8 (uint8_t * __addr, uint8x16x2_t __value)
> +{
> + union { uint8x16x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv16qi ((__builtin_neon_qi *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline uint8x16_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_u8 (uint8_t const *__base, mve_pred16_t __p)
> +{
> + return vldrbq_z_u8 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int8x16_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_s8 (int8_t const *__base, mve_pred16_t __p)
> +{
> + return vldrbq_z_s8 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int8x16x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_s8 (int8_t const * __addr)
> +{
> + union { int8x16x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv16qi ((__builtin_neon_qi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint8x16x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_u8 (uint8_t const * __addr)
> +{
> + union { uint8x16x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv16qi ((__builtin_neon_qi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline int8x16x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_s8 (int8_t const * __addr)
> +{
> + union { int8x16x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv16qi ((__builtin_neon_qi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint8x16x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_u8 (uint8_t const * __addr)
> +{
> + union { uint8x16x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv16qi ((__builtin_neon_qi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_u16 (uint16_t * __addr, uint16x8_t __value, mve_pred16_t
> __p)
> +{
> + return vstrhq_p_u16 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_s16 (int16_t * __addr, int16x8_t __value, mve_pred16_t
> __p)
> +{
> + return vstrhq_p_s16 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_s16 (int16_t * __addr, int16x8x2_t __value)
> +{
> + union { int16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv8hi ((__builtin_neon_hi *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_u16 (uint16_t * __addr, uint16x8x2_t __value)
> +{
> + union { uint16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv8hi ((__builtin_neon_hi *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline uint16x8_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_u16 (uint16_t const *__base, mve_pred16_t __p)
> +{
> + return vldrhq_z_u16 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int16x8_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_s16 (int16_t const *__base, mve_pred16_t __p)
> +{
> + return vldrhq_z_s16 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int16x8x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_s16 (int16_t const * __addr)
> +{
> + union { int16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv8hi ((__builtin_neon_hi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint16x8x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_u16 (uint16_t const * __addr)
> +{
> + union { uint16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv8hi ((__builtin_neon_hi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline int16x8x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_s16 (int16_t const * __addr)
> +{
> + union { int16x8x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv8hi ((__builtin_neon_hi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint16x8x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_u16 (uint16_t const * __addr)
> +{
> + union { uint16x8x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv8hi ((__builtin_neon_hi *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_u32 (uint32_t * __addr, uint32x4_t __value, mve_pred16_t
> __p)
> +{
> + return vstrwq_p_u32 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_s32 (int32_t * __addr, int32x4_t __value, mve_pred16_t
> __p)
> +{
> + return vstrwq_p_s32 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_s32 (int32_t * __addr, int32x4x2_t __value)
> +{
> + union { int32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv4si ((__builtin_neon_si *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_u32 (uint32_t * __addr, uint32x4x2_t __value)
> +{
> + union { uint32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv4si ((__builtin_neon_si *) __addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline uint32x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_u32 (uint32_t const *__base, mve_pred16_t __p)
> +{
> + return vldrwq_z_u32 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int32x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_s32 (int32_t const *__base, mve_pred16_t __p)
> +{
> + return vldrwq_z_s32 ( __base, __p);
> +}
> +
> +__extension__ extern __inline int32x4x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_s32 (int32_t const * __addr)
> +{
> + union { int32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv4si ((__builtin_neon_si *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint32x4x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_u32 (uint32_t const * __addr)
> +{
> + union { uint32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv4si ((__builtin_neon_si *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline int32x4x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_s32 (int32_t const * __addr)
> +{
> + union { int32x4x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv4si ((__builtin_neon_si *) __addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline uint32x4x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_u32 (uint32_t const * __addr)
> +{
> + union { uint32x4x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv4si ((__builtin_neon_si *) __addr);
> + return __rv.__i;
> +}
> +
> #if (__ARM_FEATURE_MVE & 2) /* MVE Floating point. */
>
> __extension__ extern __inline void
> @@ -19436,6 +19722,88 @@ __arm_vrev64q_x_f32 (float32x4_t __a,
> mve_pred16_t __p)
> return __builtin_mve_vrev64q_m_fv4sf (vuninitializedq_f32 (), __a, __p);
> }
>
> +__extension__ extern __inline float16x8x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_f16 (float16_t const * __addr)
> +{
> + union { float16x8x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv8hf (__addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline float16x8x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_f16 (float16_t const * __addr)
> +{
> + union { float16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv8hf (__addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline float16x8_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_f16 (float16_t const *__base, mve_pred16_t __p)
> +{
> + return vldrhq_z_f16 ( __base, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_f16 (float16_t * __addr, float16x8x2_t __value)
> +{
> + union { float16x8x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv8hf (__addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_f16 (float16_t * __addr, float16x8_t __value,
> mve_pred16_t __p)
> +{
> + return vstrhq_p_f16 (__addr, __value, __p);
> +}
> +
> +__extension__ extern __inline float32x4x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld4q_f32 (float32_t const * __addr)
> +{
> + union { float32x4x4_t __i; __builtin_neon_xi __o; } __rv;
> + __rv.__o = __builtin_mve_vld4qv4sf (__addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline float32x4x2_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld2q_f32 (float32_t const * __addr)
> +{
> + union { float32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__o = __builtin_mve_vld2qv4sf (__addr);
> + return __rv.__i;
> +}
> +
> +__extension__ extern __inline float32x4_t
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vld1q_z_f32 (float32_t const *__base, mve_pred16_t __p)
> +{
> + return vldrwq_z_f32 ( __base, __p);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst2q_f32 (float32_t * __addr, float32x4x2_t __value)
> +{
> + union { float32x4x2_t __i; __builtin_neon_oi __o; } __rv;
> + __rv.__i = __value;
> + __builtin_mve_vst2qv4sf (__addr, __rv.__o);
> +}
> +
> +__extension__ extern __inline void
> +__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
> +__arm_vst1q_p_f32 (float32_t * __addr, float32x4_t __value,
> mve_pred16_t __p)
> +{
> + return vstrwq_p_f32 (__addr, __value, __p);
> +}
> +
> #endif
>
> enum {
> @@ -21911,6 +22279,42 @@ extern void *__ARM_undef;
> int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld1q_f16
> (__ARM_mve_coerce(__p0, float16_t const *)), \
> int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld1q_f32
> (__ARM_mve_coerce(__p0, float32_t const *)));})
>
> +#define vld1q_z(p0,p1) __arm_vld1q_z(p0, p1)
> +#define __arm_vld1q_z(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld1q_z_s8
> (__ARM_mve_coerce(__p0, int8_t const *), p1), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld1q_z_s16
> (__ARM_mve_coerce(__p0, int16_t const *), p1), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld1q_z_s32
> (__ARM_mve_coerce(__p0, int32_t const *), p1), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld1q_z_u8
> (__ARM_mve_coerce(__p0, uint8_t const *), p1), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld1q_z_u16
> (__ARM_mve_coerce(__p0, uint16_t const *), p1), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld1q_z_u32
> (__ARM_mve_coerce(__p0, uint32_t const *), p1), \
> + int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld1q_z_f16
> (__ARM_mve_coerce(__p0, float16_t const *), p1), \
> + int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld1q_z_f32
> (__ARM_mve_coerce(__p0, float32_t const *), p1));})
> +
> +#define vld2q(p0) __arm_vld2q(p0)
> +#define __arm_vld2q(p0) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld2q_s8
> (__ARM_mve_coerce(__p0, int8_t const *)), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld2q_s16
> (__ARM_mve_coerce(__p0, int16_t const *)), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld2q_s32
> (__ARM_mve_coerce(__p0, int32_t const *)), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld2q_u8
> (__ARM_mve_coerce(__p0, uint8_t const *)), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld2q_u16
> (__ARM_mve_coerce(__p0, uint16_t const *)), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld2q_u32
> (__ARM_mve_coerce(__p0, uint32_t const *)), \
> + int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld2q_f16
> (__ARM_mve_coerce(__p0, float16_t const *)), \
> + int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld2q_f32
> (__ARM_mve_coerce(__p0, float32_t const *)));})
> +
> +#define vld4q(p0) __arm_vld4q(p0)
> +#define __arm_vld4q(p0) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld4q_s8
> (__ARM_mve_coerce(__p0, int8_t const *)), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld4q_s16
> (__ARM_mve_coerce(__p0, int16_t const *)), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld4q_s32
> (__ARM_mve_coerce(__p0, int32_t const *)), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld4q_u8
> (__ARM_mve_coerce(__p0, uint8_t const *)), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld4q_u16
> (__ARM_mve_coerce(__p0, uint16_t const *)), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld4q_u32
> (__ARM_mve_coerce(__p0, uint32_t const *)), \
> + int (*)[__ARM_mve_type_float16_t_const_ptr]: __arm_vld4q_f16
> (__ARM_mve_coerce(__p0, float16_t const *)), \
> + int (*)[__ARM_mve_type_float32_t_const_ptr]: __arm_vld4q_f32
> (__ARM_mve_coerce(__p0, float32_t const *)));})
> +
> #define vldrhq_gather_offset(p0,p1) __arm_vldrhq_gather_offset(p0,p1)
> #define __arm_vldrhq_gather_offset(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> __typeof(p1) __p1 = (p1); \
> @@ -21979,6 +22383,32 @@ extern void *__ARM_undef;
> int (*)[__ARM_mve_type_uint32_t_const_ptr]:
> __arm_vldrwq_gather_shifted_offset_z_u32 (__ARM_mve_coerce(__p0,
> uint32_t const *), p1, p2), \
> int (*)[__ARM_mve_type_float32_t_const_ptr]:
> __arm_vldrwq_gather_shifted_offset_z_f32 (__ARM_mve_coerce(__p0,
> float32_t const *), p1, p2));})
>
> +#define vst1q_p(p0,p1,p2) __arm_vst1q_p(p0,p1,p2)
> +#define __arm_vst1q_p(p0,p1,p2) ({ __typeof(p0) __p0 = (p0); \
> + __typeof(p1) __p1 = (p1); \
> + _Generic( (int
> (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
> + int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16_t]:
> __arm_vst1q_p_s8 (__ARM_mve_coerce(__p0, int8_t *),
> __ARM_mve_coerce(__p1, int8x16_t), p2), \
> + int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8_t]:
> __arm_vst1q_p_s16 (__ARM_mve_coerce(__p0, int16_t *),
> __ARM_mve_coerce(__p1, int16x8_t), p2), \
> + int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4_t]:
> __arm_vst1q_p_s32 (__ARM_mve_coerce(__p0, int32_t *),
> __ARM_mve_coerce(__p1, int32x4_t), p2), \
> + int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16_t]:
> __arm_vst1q_p_u8 (__ARM_mve_coerce(__p0, uint8_t *),
> __ARM_mve_coerce(__p1, uint8x16_t), p2), \
> + int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]:
> __arm_vst1q_p_u16 (__ARM_mve_coerce(__p0, uint16_t *),
> __ARM_mve_coerce(__p1, uint16x8_t), p2), \
> + int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]:
> __arm_vst1q_p_u32 (__ARM_mve_coerce(__p0, uint32_t *),
> __ARM_mve_coerce(__p1, uint32x4_t), p2), \
> + int (*)[__ARM_mve_type_float16_t_ptr][__ARM_mve_type_float16x8_t]:
> __arm_vst1q_p_f16 (__ARM_mve_coerce(__p0, float16_t *),
> __ARM_mve_coerce(__p1, float16x8_t), p2), \
> + int (*)[__ARM_mve_type_float32_t_ptr][__ARM_mve_type_float32x4_t]:
> __arm_vst1q_p_f32 (__ARM_mve_coerce(__p0, float32_t *),
> __ARM_mve_coerce(__p1, float32x4_t), p2));})
> +
> +#define vst2q(p0,p1) __arm_vst2q(p0,p1)
> +#define __arm_vst2q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> + __typeof(p1) __p1 = (p1); \
> + _Generic( (int
> (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
> + int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16x2_t]:
> __arm_vst2q_s8 (__ARM_mve_coerce(__p0, int8_t *),
> __ARM_mve_coerce(__p1, int8x16x2_t)), \
> + int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8x2_t]:
> __arm_vst2q_s16 (__ARM_mve_coerce(__p0, int16_t *),
> __ARM_mve_coerce(__p1, int16x8x2_t)), \
> + int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4x2_t]:
> __arm_vst2q_s32 (__ARM_mve_coerce(__p0, int32_t *),
> __ARM_mve_coerce(__p1, int32x4x2_t)), \
> + int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16x2_t]:
> __arm_vst2q_u8 (__ARM_mve_coerce(__p0, uint8_t *),
> __ARM_mve_coerce(__p1, uint8x16x2_t)), \
> + int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8x2_t]:
> __arm_vst2q_u16 (__ARM_mve_coerce(__p0, uint16_t *),
> __ARM_mve_coerce(__p1, uint16x8x2_t)), \
> + int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4x2_t]:
> __arm_vst2q_u32 (__ARM_mve_coerce(__p0, uint32_t *),
> __ARM_mve_coerce(__p1, uint32x4x2_t)), \
> + int (*)[__ARM_mve_type_float16_t_ptr][__ARM_mve_type_float16x8x2_t]:
> __arm_vst2q_f16 (__ARM_mve_coerce(__p0, float16_t *),
> __ARM_mve_coerce(__p1, float16x8x2_t)), \
> + int (*)[__ARM_mve_type_float32_t_ptr][__ARM_mve_type_float32x4x2_t]:
> __arm_vst2q_f32 (__ARM_mve_coerce(__p0, float32_t *),
> __ARM_mve_coerce(__p1, float32x4x2_t)));})
> +
> #define vst1q(p0,p1) __arm_vst1q(p0,p1)
> #define __arm_vst1q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> __typeof(p1) __p1 = (p1); \
> @@ -24849,6 +25279,28 @@ extern void *__ARM_undef;
> int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]:
> __arm_vst1q_u16 (__ARM_mve_coerce(__p0, uint16_t *),
> __ARM_mve_coerce(__p1, uint16x8_t)), \
> int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]:
> __arm_vst1q_u32 (__ARM_mve_coerce(__p0, uint32_t *),
> __ARM_mve_coerce(__p1, uint32x4_t)));})
>
> +#define vst1q_p(p0,p1,p2) __arm_vst1q_p(p0,p1,p2)
> +#define __arm_vst1q_p(p0,p1,p2) ({ __typeof(p0) __p0 = (p0); \
> + __typeof(p1) __p1 = (p1); \
> + _Generic( (int
> (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
> + int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16_t]:
> __arm_vst1q_p_s8 (__ARM_mve_coerce(__p0, int8_t *),
> __ARM_mve_coerce(__p1, int8x16_t), p2), \
> + int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8_t]:
> __arm_vst1q_p_s16 (__ARM_mve_coerce(__p0, int16_t *),
> __ARM_mve_coerce(__p1, int16x8_t), p2), \
> + int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4_t]:
> __arm_vst1q_p_s32 (__ARM_mve_coerce(__p0, int32_t *),
> __ARM_mve_coerce(__p1, int32x4_t), p2), \
> + int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16_t]:
> __arm_vst1q_p_u8 (__ARM_mve_coerce(__p0, uint8_t *),
> __ARM_mve_coerce(__p1, uint8x16_t), p2), \
> + int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8_t]:
> __arm_vst1q_p_u16 (__ARM_mve_coerce(__p0, uint16_t *),
> __ARM_mve_coerce(__p1, uint16x8_t), p2), \
> + int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4_t]:
> __arm_vst1q_p_u32 (__ARM_mve_coerce(__p0, uint32_t *),
> __ARM_mve_coerce(__p1, uint32x4_t), p2));})
> +
> +#define vst2q(p0,p1) __arm_vst2q(p0,p1)
> +#define __arm_vst2q(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> + __typeof(p1) __p1 = (p1); \
> + _Generic( (int
> (*)[__ARM_mve_typeid(__p0)][__ARM_mve_typeid(__p1)])0, \
> + int (*)[__ARM_mve_type_int8_t_ptr][__ARM_mve_type_int8x16x2_t]:
> __arm_vst2q_s8 (__ARM_mve_coerce(__p0, int8_t *),
> __ARM_mve_coerce(__p1, int8x16x2_t)), \
> + int (*)[__ARM_mve_type_int16_t_ptr][__ARM_mve_type_int16x8x2_t]:
> __arm_vst2q_s16 (__ARM_mve_coerce(__p0, int16_t *),
> __ARM_mve_coerce(__p1, int16x8x2_t)), \
> + int (*)[__ARM_mve_type_int32_t_ptr][__ARM_mve_type_int32x4x2_t]:
> __arm_vst2q_s32 (__ARM_mve_coerce(__p0, int32_t *),
> __ARM_mve_coerce(__p1, int32x4x2_t)), \
> + int (*)[__ARM_mve_type_uint8_t_ptr][__ARM_mve_type_uint8x16x2_t]:
> __arm_vst2q_u8 (__ARM_mve_coerce(__p0, uint8_t *),
> __ARM_mve_coerce(__p1, uint8x16x2_t)), \
> + int (*)[__ARM_mve_type_uint16_t_ptr][__ARM_mve_type_uint16x8x2_t]:
> __arm_vst2q_u16 (__ARM_mve_coerce(__p0, uint16_t *),
> __ARM_mve_coerce(__p1, uint16x8x2_t)), \
> + int (*)[__ARM_mve_type_uint32_t_ptr][__ARM_mve_type_uint32x4x2_t]:
> __arm_vst2q_u32 (__ARM_mve_coerce(__p0, uint32_t *),
> __ARM_mve_coerce(__p1, uint32x4x2_t)));})
> +
> #define vstrhq(p0,p1) __arm_vstrhq(p0,p1)
> #define __arm_vstrhq(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> __typeof(p1) __p1 = (p1); \
> @@ -25403,6 +25855,36 @@ extern void *__ARM_undef;
> int (*)[__ARM_mve_type_uint16x8_t]: __arm_vbrsrq_x_n_u16
> (__ARM_mve_coerce(__p1, uint16x8_t), p2, p3), \
> int (*)[__ARM_mve_type_uint32x4_t]: __arm_vbrsrq_x_n_u32
> (__ARM_mve_coerce(__p1, uint32x4_t), p2, p3));})
>
> +#define vld1q_z(p0,p1) __arm_vld1q_z(p0, p1)
> +#define __arm_vld1q_z(p0,p1) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld1q_z_s8
> (__ARM_mve_coerce(__p0, int8_t const *), p1), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld1q_z_s16
> (__ARM_mve_coerce(__p0, int16_t const *), p1), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld1q_z_s32
> (__ARM_mve_coerce(__p0, int32_t const *), p1), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld1q_z_u8
> (__ARM_mve_coerce(__p0, uint8_t const *), p1), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld1q_z_u16
> (__ARM_mve_coerce(__p0, uint16_t const *), p1), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld1q_z_u32
> (__ARM_mve_coerce(__p0, uint32_t const *), p1));})
> +
> +#define vld2q(p0) __arm_vld2q(p0)
> +#define __arm_vld2q(p0) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld2q_s8
> (__ARM_mve_coerce(__p0, int8_t const *)), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld2q_s16
> (__ARM_mve_coerce(__p0, int16_t const *)), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld2q_s32
> (__ARM_mve_coerce(__p0, int32_t const *)), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld2q_u8
> (__ARM_mve_coerce(__p0, uint8_t const *)), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld2q_u16
> (__ARM_mve_coerce(__p0, uint16_t const *)), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld2q_u32
> (__ARM_mve_coerce(__p0, uint32_t const *)));})
> +
> +#define vld4q(p0) __arm_vld4q(p0)
> +#define __arm_vld4q(p0) ({ __typeof(p0) __p0 = (p0); \
> + _Generic( (int (*)[__ARM_mve_typeid(__p0)])0, \
> + int (*)[__ARM_mve_type_int8_t_const_ptr]: __arm_vld4q_s8
> (__ARM_mve_coerce(__p0, int8_t const *)), \
> + int (*)[__ARM_mve_type_int16_t_const_ptr]: __arm_vld4q_s16
> (__ARM_mve_coerce(__p0, int16_t const *)), \
> + int (*)[__ARM_mve_type_int32_t_const_ptr]: __arm_vld4q_s32
> (__ARM_mve_coerce(__p0, int32_t const *)), \
> + int (*)[__ARM_mve_type_uint8_t_const_ptr]: __arm_vld4q_u8
> (__ARM_mve_coerce(__p0, uint8_t const *)), \
> + int (*)[__ARM_mve_type_uint16_t_const_ptr]: __arm_vld4q_u16
> (__ARM_mve_coerce(__p0, uint16_t const *)), \
> + int (*)[__ARM_mve_type_uint32_t_const_ptr]: __arm_vld4q_u32
> (__ARM_mve_coerce(__p0, uint32_t const *)));})
> +
> #endif /* MVE Integer. */
>
> #define vmvnq_x(p1,p2) __arm_vmvnq_x(p1,p2)
> diff --git a/gcc/config/arm/arm_mve_builtins.def
> b/gcc/config/arm/arm_mve_builtins.def
> index
> 38f46beb76a3068dcb8dd97e3ee8dbe2707dd72e..a60650cb7b1fe4e52ab1c7b
> f3c1215ff083a106f 100644
> --- a/gcc/config/arm/arm_mve_builtins.def
> +++ b/gcc/config/arm/arm_mve_builtins.def
> @@ -873,3 +873,6 @@ VAR1 (QUADOP_NONE_NONE_NONE_NONE_UNONE,
> vsbciq_m_s, v4si)
> VAR1 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE, vsbciq_m_u,
> v4si)
> VAR1 (QUADOP_NONE_NONE_NONE_NONE_UNONE, vsbcq_m_s, v4si)
> VAR1 (QUADOP_UNONE_UNONE_UNONE_UNONE_UNONE, vsbcq_m_u, v4si)
> +VAR5 (STORE1, vst2q, v16qi, v8hi, v4si, v8hf, v4sf)
> +VAR5 (LOAD1, vld4q, v16qi, v8hi, v4si, v8hf, v4sf)
> +VAR5 (LOAD1, vld2q, v16qi, v8hi, v4si, v8hf, v4sf)
> diff --git a/gcc/config/arm/mve.md b/gcc/config/arm/mve.md
> index
> 25b59732d257a19f38ff7e54898df5cef4fdef3d..2e28d9d8408127dd52b9d16c
> 772e7f27a47d390a 100644
> --- a/gcc/config/arm/mve.md
> +++ b/gcc/config/arm/mve.md
> @@ -214,7 +214,7 @@
> VLDRDQGBWB_S VLDRDQGBWB_U VADCQ_U
> VADCQ_M_U VADCQ_S
> VADCQ_M_S VSBCIQ_U VSBCIQ_S VSBCIQ_M_U
> VSBCIQ_M_S
> VSBCQ_U VSBCQ_S VSBCQ_M_U VSBCQ_M_S
> VADCIQ_U VADCIQ_M_U
> - VADCIQ_S VADCIQ_M_S])
> + VADCIQ_S VADCIQ_M_S VLD2Q VLD4Q VST2Q])
>
> (define_mode_attr MVE_CNVT [(V8HI "V8HF") (V4SI "V4SF") (V8HF "V8HI")
> (V4SF "V4SI")])
> @@ -10797,3 +10797,91 @@
> "vsbc.i32\t%q0, %q1, %q2"
> [(set_attr "type" "mve_move")
> (set_attr "length" "4")])
> +
> +;;
> +;; [vst2q])
> +;;
> +(define_insn "mve_vst2q<mode>"
> + [(set (match_operand:OI 0 "neon_struct_operand" "=Um")
> + (unspec:OI [(match_operand:OI 1 "s_register_operand" "w")
> + (unspec:MVE_VLD_ST [(const_int 0)]
> UNSPEC_VSTRUCTDUMMY)]
> + VST2Q))
> + ]
> + "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
> + || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE
> (<MODE>mode))"
> +{
> + rtx ops[4];
> + int regno = REGNO (operands[1]);
> + ops[0] = gen_rtx_REG (TImode, regno);
> + ops[1] = gen_rtx_REG (TImode, regno + 4);
> + rtx reg = operands[0];
> + while (reg && !REG_P (reg))
> + reg = XEXP (reg, 0);
> + gcc_assert (REG_P (reg));
> + ops[2] = reg;
> + ops[3] = operands[0];
> + output_asm_insn ("vst20.<V_sz_elem>\t{%q0, %q1}, [%2]\n\t"
> + "vst21.<V_sz_elem>\t{%q0, %q1}, %3", ops);
> + return "";
> +}
> + [(set_attr "length" "8")])
> +
> +;;
> +;; [vld2q])
> +;;
> +(define_insn "mve_vld2q<mode>"
> + [(set (match_operand:OI 0 "s_register_operand" "=w")
> + (unspec:OI [(match_operand:OI 1 "neon_struct_operand" "Um")
> + (unspec:MVE_VLD_ST [(const_int 0)]
> UNSPEC_VSTRUCTDUMMY)]
> + VLD2Q))
> + ]
> + "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
> + || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE
> (<MODE>mode))"
> +{
> + rtx ops[4];
> + int regno = REGNO (operands[0]);
> + ops[0] = gen_rtx_REG (TImode, regno);
> + ops[1] = gen_rtx_REG (TImode, regno + 4);
> + rtx reg = operands[1];
> + while (reg && !REG_P (reg))
> + reg = XEXP (reg, 0);
> + gcc_assert (REG_P (reg));
> + ops[2] = reg;
> + ops[3] = operands[1];
> + output_asm_insn ("vld20.<V_sz_elem>\t{%q0, %q1}, [%2]\n\t"
> + "vld21.<V_sz_elem>\t{%q0, %q1}, %3", ops);
> + return "";
> +}
> + [(set_attr "length" "8")])
> +
> +;;
> +;; [vld4q])
> +;;
> +(define_insn "mve_vld4q<mode>"
> + [(set (match_operand:XI 0 "s_register_operand" "=w")
> + (unspec:XI [(match_operand:XI 1 "neon_struct_operand" "Um")
> + (unspec:MVE_VLD_ST [(const_int 0)]
> UNSPEC_VSTRUCTDUMMY)]
> + VLD4Q))
> + ]
> + "(TARGET_HAVE_MVE && VALID_MVE_SI_MODE (<MODE>mode))
> + || (TARGET_HAVE_MVE_FLOAT && VALID_MVE_SF_MODE
> (<MODE>mode))"
> +{
> + rtx ops[6];
> + int regno = REGNO (operands[0]);
> + ops[0] = gen_rtx_REG (TImode, regno);
> + ops[1] = gen_rtx_REG (TImode, regno+4);
> + ops[2] = gen_rtx_REG (TImode, regno+8);
> + ops[3] = gen_rtx_REG (TImode, regno + 12);
> + rtx reg = operands[1];
> + while (reg && !REG_P (reg))
> + reg = XEXP (reg, 0);
> + gcc_assert (REG_P (reg));
> + ops[4] = reg;
> + ops[5] = operands[1];
> + output_asm_insn ("vld40.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
> + "vld41.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
> + "vld42.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, [%4]\n\t"
> + "vld43.<V_sz_elem>\t{%q0, %q1, %q2, %q3}, %5", ops);
> + return "";
> +}
> + [(set_attr "length" "16")])
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..830d817d14353645c4b647
> 069cc37cb61b28d6c2
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float16x8_t
> +foo (float16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_f16 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.f16" } } */
> +
> +float16x8_t
> +foo1 (float16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.f16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..84f976a6605949cf4ce565df
> b426ea9e57d775db
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_f32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float32x4_t
> +foo (float32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_f32 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.f32" } } */
> +
> +float32x4_t
> +foo1 (float32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.f32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..8bb7ef34d69ed9827d0d3a
> 2576457883ed6be30b
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int16x8_t
> +foo (int16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_s16 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.s16" } } */
> +
> +int16x8_t
> +foo1 (int16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.s16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..f5d7cc0396f0dbb55b463b4
> 919cb4ad84ce01f6d
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int32x4_t
> +foo (int32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_s32 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.s32" } } */
> +
> +int32x4_t
> +foo1 (int32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.s32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..a3999e680277ce3e0e00e5e
> 4a826df9a31dfa714
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_s8.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int8x16_t
> +foo (int8_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_s8 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrbt.s8" } } */
> +
> +int8x16_t
> +foo1 (int8_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrbt.s8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..ada9c2ff1aacae47811d8b1
> 2b6f70f2085722bdf
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint16x8_t
> +foo (uint16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_u16 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.u16" } } */
> +
> +uint16x8_t
> +foo1 (uint16_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrht.u16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..c96be7b76c2b6158e36a7b
> ba0e41b0bb94363050
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint32x4_t
> +foo (uint32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_u32 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.u32" } } */
> +
> +uint32x4_t
> +foo1 (uint32_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrwt.u32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..faca38dd99584b05e8d9c3d
> 3bdb376e6cd0ecadf
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld1q_z_u8.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint8x16_t
> +foo (uint8_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z_u8 (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrbt.u8" } } */
> +
> +uint8x16_t
> +foo1 (uint8_t const * base, mve_pred16_t p)
> +{
> + return vld1q_z (base, p);
> +}
> +
> +/* { dg-final { scan-assembler "vldrbt.u8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..cb2bc6f9c4dda8777ea9117
> 1e3aa178a9c5528ed
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float16x8x2_t
> +foo (float16_t const * addr)
> +{
> + return vld2q_f16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> +/* { dg-final { scan-assembler "vld21.16" } } */
> +
> +float16x8x2_t
> +foo1 (float16_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..f701d3d4cbcd992dda9abad
> fbcc7e222eb7a6fad
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_f32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float32x4x2_t
> +foo (float32_t const * addr)
> +{
> + return vld2q_f32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> +/* { dg-final { scan-assembler "vld21.32" } } */
> +
> +float32x4x2_t
> +foo1 (float32_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..85e844cea441ea08b47d8ff
> ba59aa2a8c59a7b2a
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int16x8x2_t
> +foo (int16_t const * addr)
> +{
> + return vld2q_s16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> +/* { dg-final { scan-assembler "vld21.16" } } */
> +
> +int16x8x2_t
> +foo1 (int16_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..f46a9d17fe987de4174f646
> 4a79db6598094166e
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int32x4x2_t
> +foo (int32_t const * addr)
> +{
> + return vld2q_s32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> +/* { dg-final { scan-assembler "vld21.32" } } */
> +
> +int32x4x2_t
> +foo1 (int32_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..29dc2885f1231bb82619380
> d70a9d51164494642
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_s8.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int8x16x2_t
> +foo (int8_t const * addr)
> +{
> + return vld2q_s8 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.8" } } */
> +/* { dg-final { scan-assembler "vld21.8" } } */
> +
> +int8x16x2_t
> +foo1 (int8_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..7d867b5b7a4ac980c132c43
> 8f6b2d810c938d502
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint16x8x2_t
> +foo (uint16_t const * addr)
> +{
> + return vld2q_u16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> +/* { dg-final { scan-assembler "vld21.16" } } */
> +
> +uint16x8x2_t
> +foo1 (uint16_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..6c9d12e9cd8e0061f75e24e
> f6a4d822a4c394a66
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint32x4x2_t
> +foo (uint32_t const * addr)
> +{
> + return vld2q_u32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> +/* { dg-final { scan-assembler "vld21.32" } } */
> +
> +uint32x4x2_t
> +foo1 (uint32_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..002a645342748373fa010b5
> d6e89d40ad5aa192a
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld2q_u8.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint8x16x2_t
> +foo (uint8_t const * addr)
> +{
> + return vld2q_u8 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.8" } } */
> +/* { dg-final { scan-assembler "vld21.8" } } */
> +
> +uint8x16x2_t
> +foo1 (uint8_t const * addr)
> +{
> + return vld2q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld20.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..386b71b35258eab2031d62
> d49cb5578f22e0557b
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f16.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float16x8x4_t
> +foo (float16_t const * addr)
> +{
> + return vld4q_f16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> +/* { dg-final { scan-assembler "vld41.16" } } */
> +/* { dg-final { scan-assembler "vld42.16" } } */
> +/* { dg-final { scan-assembler "vld43.16" } } */
> +
> +float16x8x4_t
> +foo1 (float16_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..c38bb54a4ca11689a1f7754
> 707561b3e4eee0426
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_f32.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +float32x4x4_t
> +foo (float32_t const * addr)
> +{
> + return vld4q_f32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> +/* { dg-final { scan-assembler "vld41.32" } } */
> +/* { dg-final { scan-assembler "vld42.32" } } */
> +/* { dg-final { scan-assembler "vld43.32" } } */
> +
> +float32x4x4_t
> +foo1 (float32_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..68e6b98fec298cf07c4d0b97
> bbe063ea34c4c8ac
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s16.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int16x8x4_t
> +foo (int16_t const * addr)
> +{
> + return vld4q_s16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> +/* { dg-final { scan-assembler "vld41.16" } } */
> +/* { dg-final { scan-assembler "vld42.16" } } */
> +/* { dg-final { scan-assembler "vld43.16" } } */
> +
> +int16x8x4_t
> +foo1 (int16_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..db0ba20bfb193b2cf2d59f9
> 40bb1595799cc428e
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s32.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int32x4x4_t
> +foo (int32_t const * addr)
> +{
> + return vld4q_s32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> +/* { dg-final { scan-assembler "vld41.32" } } */
> +/* { dg-final { scan-assembler "vld42.32" } } */
> +/* { dg-final { scan-assembler "vld43.32" } } */
> +
> +int32x4x4_t
> +foo1 (int32_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..e38bdeab87bd19eaf0e933c
> 7551a84130e3afd97
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_s8.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +int8x16x4_t
> +foo (int8_t const * addr)
> +{
> + return vld4q_s8 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.8" } } */
> +/* { dg-final { scan-assembler "vld41.8" } } */
> +/* { dg-final { scan-assembler "vld42.8" } } */
> +/* { dg-final { scan-assembler "vld43.8" } } */
> +
> +int8x16x4_t
> +foo1 (int8_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..7f6a7838fc0889db889e800
> b2380287908f5d8b9
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u16.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint16x8x4_t
> +foo (uint16_t const * addr)
> +{
> + return vld4q_u16 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> +/* { dg-final { scan-assembler "vld41.16" } } */
> +/* { dg-final { scan-assembler "vld42.16" } } */
> +/* { dg-final { scan-assembler "vld43.16" } } */
> +
> +uint16x8x4_t
> +foo1 (uint16_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..29af573735335d1d86141da
> f259d622a6e84f338
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u32.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint32x4x4_t
> +foo (uint32_t const * addr)
> +{
> + return vld4q_u32 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> +/* { dg-final { scan-assembler "vld41.32" } } */
> +/* { dg-final { scan-assembler "vld42.32" } } */
> +/* { dg-final { scan-assembler "vld43.32" } } */
> +
> +uint32x4x4_t
> +foo1 (uint32_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..f54036229c60ab55cafd4fc5
> eae5d584b3e50a6c
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vld4q_u8.c
> @@ -0,0 +1,25 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +uint8x16x4_t
> +foo (uint8_t const * addr)
> +{
> + return vld4q_u8 (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.8" } } */
> +/* { dg-final { scan-assembler "vld41.8" } } */
> +/* { dg-final { scan-assembler "vld42.8" } } */
> +/* { dg-final { scan-assembler "vld43.8" } } */
> +
> +uint8x16x4_t
> +foo1 (uint8_t const * addr)
> +{
> + return vld4q (addr);
> +}
> +
> +/* { dg-final { scan-assembler "vld40.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..7ef5ccee663c609c2d8f5cee
> cca3e115f697d955
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (float16_t * addr, float16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p_f16 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> +
> +void
> +foo1 (float16_t * addr, float16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..2cd7221985a663703e5a4c2
> a3ae266079b68c007
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_f32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (float32_t * addr, float32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p_f32 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> +
> +void
> +foo1 (float32_t * addr, float32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..ca56f7384aca48985428517
> 06cfed60255c281e1
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int16_t * addr, int16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p_s16 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> +
> +void
> +foo1 (int16_t * addr, int16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..782496f458967f3f0489350a
> 91701ca0e4a943e8
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int32_t * addr, int32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p_s32 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> +
> +void
> +foo1 (int32_t * addr, int32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..92bbc0a239a0a3dcc92f066
> 55a8dfe43f11d603c
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_s8.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int8_t * addr, int8x16_t value, mve_pred16_t p)
> +{
> + vst1q_p_s8 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrbt.8" } } */
> +
> +void
> +foo1 (int8_t * addr, int8x16_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrbt.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..12c50f7b137a49e7f1f78df6
> 12830e7dfeb4ffbd
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u16.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint16_t * addr, uint16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p_u16 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> +
> +void
> +foo1 (uint16_t * addr, uint16x8_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrht.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..2f7ef61aaaef135644c611c3
> efb2e3fadd0c38a7
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u32.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint32_t * addr, uint32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p_u32 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> +
> +void
> +foo1 (uint32_t * addr, uint32x4_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrwt.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..56fde60c54b380e89a62ac0
> 13e828298b788a288
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst1q_p_u8.c
> @@ -0,0 +1,22 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint8_t * addr, uint8x16_t value, mve_pred16_t p)
> +{
> + vst1q_p_u8 (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrbt.8" } } */
> +
> +void
> +foo1 (uint8_t * addr, uint8x16_t value, mve_pred16_t p)
> +{
> + vst1q_p (addr, value, p);
> +}
> +
> +/* { dg-final { scan-assembler "vstrbt.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..79e1b5c035526dcf70a7c16
> 5817198869ee4060d
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (float16_t * addr, float16x8x2_t value)
> +{
> + vst2q_f16 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> +/* { dg-final { scan-assembler "vst21.16" } } */
> +
> +void
> +foo1 (float16_t * addr, float16x8x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..7d256aacd33d1d7dbc4c47c
> 7612499eb427cf27f
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_f32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_fp_ok } */
> +/* { dg-add-options arm_v8_1m_mve_fp } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (float32_t * addr, float32x4x2_t value)
> +{
> + vst2q_f32 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> +/* { dg-final { scan-assembler "vst21.32" } } */
> +
> +void
> +foo1 (float32_t * addr, float32x4x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..f2fd867b877a4b129a33e83
> d5b102be627449bd5
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int16_t * addr, int16x8x2_t value)
> +{
> + vst2q_s16 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> +/* { dg-final { scan-assembler "vst21.16" } } */
> +
> +void
> +foo1 (int16_t * addr, int16x8x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..85e36df48a339b4a658c56b
> 1e0a156f89fd0a2b2
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int32_t * addr, int32x4x2_t value)
> +{
> + vst2q_s32 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> +/* { dg-final { scan-assembler "vst21.32" } } */
> +
> +void
> +foo1 (int32_t * addr, int32x4x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..57e9efc44f16cb4db6317d1
> 7bf38edd06e0ea78a
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_s8.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (int8_t * addr, int8x16x2_t value)
> +{
> + vst2q_s8 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.8" } } */
> +/* { dg-final { scan-assembler "vst21.8" } } */
> +
> +void
> +foo1 (int8_t * addr, int8x16x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.8" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..b54c79157b20bde98cb505f
> a4291049560676ed0
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u16.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint16_t * addr, uint16x8x2_t value)
> +{
> + vst2q_u16 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> +/* { dg-final { scan-assembler "vst21.16" } } */
> +
> +void
> +foo1 (uint16_t * addr, uint16x8x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.16" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..167f8bdb14e418e888a58ab
> 0ca157abac1484549
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u32.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint32_t * addr, uint32x4x2_t value)
> +{
> + vst2q_u32 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> +/* { dg-final { scan-assembler "vst21.32" } } */
> +
> +void
> +foo1 (uint32_t * addr, uint32x4x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.32" } } */
> diff --git a/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c
> b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c
> new file mode 100644
> index
> 0000000000000000000000000000000000000000..9f7a5f1a7c00fc6a17e46935
> ca0b174cbfca8979
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/arm/mve/intrinsics/vst2q_u8.c
> @@ -0,0 +1,23 @@
> +/* { dg-do compile } */
> +/* { dg-require-effective-target arm_v8_1m_mve_ok } */
> +/* { dg-add-options arm_v8_1m_mve } */
> +/* { dg-additional-options "-O2" } */
> +
> +#include "arm_mve.h"
> +
> +void
> +foo (uint8_t * addr, uint8x16x2_t value)
> +{
> + vst2q_u8 (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.8" } } */
> +/* { dg-final { scan-assembler "vst21.8" } } */
> +
> +void
> +foo1 (uint8_t * addr, uint8x16x2_t value)
> +{
> + vst2q (addr, value);
> +}
> +
> +/* { dg-final { scan-assembler "vst20.8" } } */
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2020-03-20 16:58 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-03-20 16:42 [PATCH v2][ARM][GCC][11x]: MVE ACLE vector interleaving store and deinterleaving load intrinsics and also aliases to vstr and vldr intrinsics Srinath Parvathaneni
2020-03-20 16:58 ` Kyrylo Tkachov
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).