[ARM/AArch64][testsuite] Add vmlal_n and vmlsl_n tests.
[official-gcc.git] / gcc / testsuite / gcc.target / aarch64 / advsimd-intrinsics / vbic.c
blob83e57ff2d610697bc41ffcc98209927a24bb6422
1 #define INSN_NAME vbic
2 #define TEST_MSG "VBIC/VBICQ"
4 #include "binary_op.inc"
6 /* Expected results. */
7 VECT_VAR_DECL(expected,int,8,8) [] = { 0xf0, 0xf1, 0xf0, 0xf1,
8 0xf4, 0xf5, 0xf4, 0xf5 };
9 VECT_VAR_DECL(expected,int,16,4) [] = { 0x0, 0x1, 0x2, 0x3 };
10 VECT_VAR_DECL(expected,int,32,2) [] = { 0xfffffff0, 0xfffffff0 };
11 VECT_VAR_DECL(expected,int,64,1) [] = { 0xffffffffffffff90 };
12 VECT_VAR_DECL(expected,uint,8,8) [] = { 0xe0, 0xe1, 0xe2, 0xe3,
13 0xe0, 0xe1, 0xe2, 0xe3 };
14 VECT_VAR_DECL(expected,uint,16,4) [] = { 0xffe0, 0xffe1, 0xffe0, 0xffe1 };
15 VECT_VAR_DECL(expected,uint,32,2) [] = { 0xffffffd0, 0xffffffd1 };
16 VECT_VAR_DECL(expected,uint,64,1) [] = { 0xfffffffffffffff0 };
17 VECT_VAR_DECL(expected,poly,8,8) [] = { 0x33, 0x33, 0x33, 0x33,
18 0x33, 0x33, 0x33, 0x33 };
19 VECT_VAR_DECL(expected,poly,16,4) [] = { 0x3333, 0x3333, 0x3333, 0x3333 };
20 VECT_VAR_DECL(expected,hfloat,32,2) [] = { 0x33333333, 0x33333333 };
21 VECT_VAR_DECL(expected,int,8,16) [] = { 0x0, 0x1, 0x0, 0x1,
22 0x0, 0x1, 0x0, 0x1,
23 0x8, 0x9, 0x8, 0x9,
24 0x8, 0x9, 0x8, 0x9 };
25 VECT_VAR_DECL(expected,int,16,8) [] = { 0x10, 0x11, 0x12, 0x13,
26 0x10, 0x11, 0x12, 0x13 };
27 VECT_VAR_DECL(expected,int,32,4) [] = { 0x10, 0x11, 0x10, 0x11 };
28 VECT_VAR_DECL(expected,int,64,2) [] = { 0xffffffffffffffe0, 0xffffffffffffffe1 };
29 VECT_VAR_DECL(expected,uint,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
30 0xf0, 0xf1, 0xf2, 0xf3,
31 0xf0, 0xf1, 0xf2, 0xf3,
32 0xf0, 0xf1, 0xf2, 0xf3 };
33 VECT_VAR_DECL(expected,uint,16,8) [] = { 0xfff0, 0xfff0, 0xfff0, 0xfff0,
34 0xfff4, 0xfff4, 0xfff4, 0xfff4 };
35 VECT_VAR_DECL(expected,uint,32,4) [] = { 0xffffffc0, 0xffffffc0,
36 0xffffffc0, 0xffffffc0 };
37 VECT_VAR_DECL(expected,uint,64,2) [] = { 0xfffffffffffffff0,
38 0xfffffffffffffff0 };
39 VECT_VAR_DECL(expected,poly,8,16) [] = { 0x33, 0x33, 0x33, 0x33,
40 0x33, 0x33, 0x33, 0x33,
41 0x33, 0x33, 0x33, 0x33,
42 0x33, 0x33, 0x33, 0x33 };
43 VECT_VAR_DECL(expected,poly,16,8) [] = { 0x3333, 0x3333, 0x3333, 0x3333,
44 0x3333, 0x3333, 0x3333, 0x3333 };
45 VECT_VAR_DECL(expected,hfloat,32,4) [] = { 0x33333333, 0x33333333,
46 0x33333333, 0x33333333 };