Mercurial > hg > CbC > CbC_gcc
view gcc/testsuite/gcc.target/arm/mve/intrinsics/mve_immediates_1_n.c @ 152:2b5abeee2509
update gcc11
author | anatofuz |
---|---|
date | Mon, 25 May 2020 07:50:57 +0900 |
parents | |
children |
line wrap: on
line source
/* { 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" uint8x16_t u8; int8x16_t s8; uint16x8_t u16; int16x8_t s16; uint32x4_t u32; int32x4_t s32; float16x8_t f16; float32x4_t f32; #define MACRO_VCVT_NAME(__to1,__from1) \ vcvtq_n_##__to1 ## _ ##__from1 #define MACRO_VCVT_NAME_P(__to1,__from1) \ vcvtq_m_n_##__to1 ## _ ##__from1 #define VCVT_TEST(to,from,val) \ to = MACRO_VCVT_NAME(to,from) (from, val); \ to = MACRO_VCVT_NAME_P(to,from) (to, from, val, p); #define VQSHRN_TEST(to,from,val) \ to = vqshrnbq (to, from, val); \ to = vqshrntq (to, from, val); \ to = vqshrnbq_m (to, from, val, p); \ to = vqshrntq_m (to, from, val, p); \ #define VQSHRUN_TEST(to,from,val) \ to = vqshrunbq (to, from, val); \ to = vqshruntq (to, from, val); \ to = vqshrunbq_m (to, from, val, p); \ to = vqshruntq_m (to, from, val, p); \ void test (mve_pred16_t p) { VCVT_TEST(f16,s16,16) VCVT_TEST(f16,u16,16) VCVT_TEST(f32,s32,32) VCVT_TEST(f32,u32,32) VCVT_TEST(u16,f16,16) VCVT_TEST(s16,f16,16) VCVT_TEST(u32,f32,32) VCVT_TEST(s32,f32,32) VCVT_TEST(f16,s16,1) VCVT_TEST(f16,u16,1) VCVT_TEST(f32,s32,1) VCVT_TEST(f32,u32,1) VCVT_TEST(u16,f16,1) VCVT_TEST(s16,f16,1) VCVT_TEST(u32,f32,1) VCVT_TEST(s32,f32,1) VQSHRN_TEST(u8, u16, 8) VQSHRN_TEST(s8, s16, 8) VQSHRN_TEST(u16, u32, 16) VQSHRN_TEST(s16, s32, 16) VQSHRUN_TEST(u8, s16, 8) VQSHRUN_TEST(u16, s32, 16) }