__builtin_neon_vst1_x2di ((__builtin_neon_di *) __a, __bu.__o);
}
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_p64_x3 (poly64_t * __a, poly64x1x3_t __b)
-{
- union { poly64x1x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3di ((__builtin_neon_di *) __a, __bu.__o);
-}
-
#pragma GCC pop_options
__extension__ extern __inline void
__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
__builtin_neon_vst1_x2di ((__builtin_neon_di *) __a, __bu.__o);
}
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_s8_x3 (int8_t * __a, int8x8x3_t __b)
-{
- union { int8x8x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v8qi ((__builtin_neon_qi *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_s16_x3 (int16_t * __a, int16x4x3_t __b)
-{
- union { int16x4x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v4hi ((__builtin_neon_hi *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_s32_x3 (int32_t * __a, int32x2x3_t __b)
-{
- union { int32x2x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v2si ((__builtin_neon_si *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_s64_x3 (int64_t * __a, int64x1x3_t __b)
-{
- union { int64x1x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3di ((__builtin_neon_di *) __a, __bu.__o);
-}
-
#if defined (__ARM_FP16_FORMAT_IEEE) || defined (__ARM_FP16_FORMAT_ALTERNATIVE)
__extension__ extern __inline void
__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
__builtin_neon_vst1_x2v2sf ((__builtin_neon_sf *) __a, __bu.__o);
}
-#if defined (__ARM_FP16_FORMAT_IEEE) || defined (__ARM_FP16_FORMAT_ALTERNATIVE)
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_f16_x3 (float16_t * __a, float16x4x3_t __b)
-{
- union { float16x4x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v4hf (__a, __bu.__o);
-}
-#endif
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_f32_x3 (float32_t * __a, float32x2x3_t __b)
-{
- union { float32x2x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v2sf ((__builtin_neon_sf *) __a, __bu.__o);
-}
-
__extension__ extern __inline void
__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
vst1_u8 (uint8_t * __a, uint8x8_t __b)
__builtin_neon_vst1_x2di ((__builtin_neon_di *) __a, __bu.__o);
}
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_u8_x3 (uint8_t * __a, uint8x8x3_t __b)
-{
- union { uint8x8x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v8qi ((__builtin_neon_qi *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_u16_x3 (uint16_t * __a, uint16x4x3_t __b)
-{
- union { uint16x4x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v4hi ((__builtin_neon_hi *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_u32_x3 (uint32_t * __a, uint32x2x3_t __b)
-{
- union { uint32x2x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v2si ((__builtin_neon_si *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_u64_x3 (uint64_t * __a, uint64x1x3_t __b)
-{
- union { uint64x1x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3di ((__builtin_neon_di *) __a, __bu.__o);
-}
-
__extension__ extern __inline void
__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
vst1_p8 (poly8_t * __a, poly8x8_t __b)
__builtin_neon_vst1_x2v4hi ((__builtin_neon_hi *) __a, __bu.__o);
}
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_p8_x3 (poly8_t * __a, poly8x8x3_t __b)
-{
- union { poly8x8x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v8qi ((__builtin_neon_qi *) __a, __bu.__o);
-}
-
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_p16_x3 (poly16_t * __a, poly16x4x3_t __b)
-{
- union { poly16x4x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v4hi ((__builtin_neon_hi *) __a, __bu.__o);
-}
-
#pragma GCC push_options
#pragma GCC target ("fpu=crypto-neon-fp-armv8")
__extension__ extern __inline void
__builtin_neon_vst1_x2v4bf ((__builtin_neon_bf *) __a, __bu.__o);
}
-__extension__ extern __inline void
-__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
-vst1_bf16_x3 (bfloat16_t * __a, bfloat16x4x3_t __b)
-{
- union { bfloat16x4x3_t __i; __builtin_neon_ei __o; } __bu = { __b };
- __builtin_neon_vst1_x3v4bf ((__builtin_neon_bf *) __a, __bu.__o);
-}
-
__extension__ extern __inline void
__attribute__ ((__always_inline__, __gnu_inline__, __artificial__))
vst1q_bf16 (bfloat16_t * __a, bfloat16x8_t __b)
vst1_p16_x2 (ptr, val);
}
-void test_vst1_u8_x3 (uint8_t * ptr, uint8x8x3_t val)
-{
- vst1_u8_x3 (ptr, val);
-}
-
-void test_vst1_u16_x3 (uint16_t * ptr, uint16x4x3_t val)
-{
- vst1_u16_x3 (ptr, val);
-}
-
-void test_vst1_u32_x3 (uint32_t * ptr, uint32x2x3_t val)
-{
- vst1_u32_x3 (ptr, val);
-}
-
-void test_vst1_u64_x3 (uint64_t * ptr, uint64x1x3_t val)
-{
- vst1_u64_x3 (ptr, val);
-}
-
-void test_vst1_s8_x3 (int8_t * ptr, int8x8x3_t val)
-{
- vst1_s8_x3 (ptr, val);
-}
-
-void test_vst1_s16_x3 (int16_t * ptr, int16x4x3_t val)
-{
- vst1_s16_x3 (ptr, val);
-}
-
-void test_vst1_s32_x3 (int32_t * ptr, int32x2x3_t val)
-{
- vst1_s32_x3 (ptr, val);
-}
-
-void test_vst1_s64_x3 (int64_t * ptr, int64x1x3_t val)
-{
- vst1_s64_x3 (ptr, val);
-}
-
-void test_vst1_f32_x3 (float32_t * ptr, float32x2x3_t val)
-{
- vst1_f32_x3 (ptr, val);
-}
-
-void test_vst1_p8_x3 (poly8_t * ptr, poly8x8x3_t val)
-{
- vst1_p8_x3 (ptr, val);
-}
-
-void test_vst1_p16_x3 (poly16_t * ptr, poly16x4x3_t val)
-{
- vst1_p16_x3 (ptr, val);
-}
-
-/* { dg-final { scan-assembler-times {vst1.8\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 6 } } */
-/* { dg-final { scan-assembler-times {vst1.16\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 6 } } */
-/* { dg-final { scan-assembler-times {vst1.32\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 6 } } */
-/* { dg-final { scan-assembler-times {vst1.64\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+:64\]\n} 4 } } */
+/* { dg-final { scan-assembler-times {vst1.8\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 3 } } */
+/* { dg-final { scan-assembler-times {vst1.16\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 3 } } */
+/* { dg-final { scan-assembler-times {vst1.32\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+\]\n} 3 } } */
+/* { dg-final { scan-assembler-times {vst1.64\t\{d[0-9]+-d[0-9]+\}, \[r[0-9]+:64\]\n} 2 } } */