2 #include "arm-neon-ref.h"
3 #include "compute-ref-data.h"
5 /* Expected results. */
6 VECT_VAR_DECL(expected,int,8,8) [] = { 0x33, 0x33, 0x33, 0x33,
7 0x33, 0x33, 0x33, 0x33 };
8 VECT_VAR_DECL(expected,int,16,4) [] = { 0x3333, 0x3333, 0x3333, 0x3333 };
9 VECT_VAR_DECL(expected,int,32,2) [] = { 0x33333333, 0x33333333 };
10 VECT_VAR_DECL(expected,int,64,1) [] = { 0x3333333333333333 };
11 VECT_VAR_DECL(expected,uint,8,8) [] = { 0x33, 0x33, 0x33, 0x33,
12 0x33, 0x33, 0x33, 0x33 };
13 VECT_VAR_DECL(expected,uint,16,4) [] = { 0x3333, 0x3333, 0x3333, 0x3333 };
14 VECT_VAR_DECL(expected,uint,32,2) [] = { 0x33333333, 0x33333333 };
15 VECT_VAR_DECL(expected,uint,64,1) [] = { 0x3333333333333333 };
16 VECT_VAR_DECL(expected,poly,8,8) [] = { 0x33, 0x33, 0x33, 0x33,
17 0x33, 0x33, 0x33, 0x33 };
18 VECT_VAR_DECL(expected,poly,16,4) [] = { 0x3333, 0x3333, 0x3333, 0x3333 };
19 VECT_VAR_DECL(expected,hfloat,32,2) [] = { 0x33333333, 0x33333333 };
20 VECT_VAR_DECL(expected,int,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
21 0xf4, 0xf5, 0xf6, 0xf7,
22 0x11, 0x11, 0x11, 0x11,
23 0x11, 0x11, 0x11, 0x11 };
24 VECT_VAR_DECL(expected,int,16,8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff3,
25 0x22, 0x22, 0x22, 0x22 };
26 VECT_VAR_DECL(expected,int,32,4) [] = { 0xfffffff0, 0xfffffff1, 0x33, 0x33 };
27 VECT_VAR_DECL(expected,int,64,2) [] = { 0xfffffffffffffff0, 0x44 };
28 VECT_VAR_DECL(expected,uint,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
29 0xf4, 0xf5, 0xf6, 0xf7,
30 0x55, 0x55, 0x55, 0x55,
31 0x55, 0x55, 0x55, 0x55 };
32 VECT_VAR_DECL(expected,uint,16,8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff3,
33 0x66, 0x66, 0x66, 0x66 };
34 VECT_VAR_DECL(expected,uint,32,4) [] = { 0xfffffff0, 0xfffffff1, 0x77, 0x77 };
35 VECT_VAR_DECL(expected,uint,64,2) [] = { 0xfffffffffffffff0, 0x88 };
36 VECT_VAR_DECL(expected,poly,8,16) [] = { 0xf0, 0xf1, 0xf2, 0xf3,
37 0xf4, 0xf5, 0xf6, 0xf7,
38 0x55, 0x55, 0x55, 0x55,
39 0x55, 0x55, 0x55, 0x55 };
40 VECT_VAR_DECL(expected,poly,16,8) [] = { 0xfff0, 0xfff1, 0xfff2, 0xfff3,
41 0x66, 0x66, 0x66, 0x66 };
42 VECT_VAR_DECL(expected,hfloat,32,4) [] = { 0xc1800000, 0xc1700000,
43 0x40533333, 0x40533333 };
45 #define TEST_MSG "VCOMBINE"
46 void exec_vcombine (void)
48 /* Basic test: vec128=vcombine(vec64_a, vec64_b), then store the result. */
49 #define TEST_VCOMBINE(T1, T2, W, N, N2) \
50 VECT_VAR(vector128, T1, W, N2) = \
51 vcombine_##T2##W(VECT_VAR(vector64_a, T1, W, N), \
52 VECT_VAR(vector64_b, T1, W, N)); \
53 vst1q_##T2##W(VECT_VAR(result, T1, W, N2), VECT_VAR(vector128, T1, W, N2))
55 DECL_VARIABLE_64BITS_VARIANTS(vector64_a);
56 DECL_VARIABLE_64BITS_VARIANTS(vector64_b);
57 DECL_VARIABLE_128BITS_VARIANTS(vector128);
59 /* Initialize input "vector64_a" from "buffer". */
60 TEST_MACRO_64BITS_VARIANTS_2_5(VLOAD, vector64_a, buffer);
61 VLOAD(vector64_a, buffer, , float, f, 32, 2);
63 /* Choose init value arbitrarily. */
64 VDUP(vector64_b, , int, s, 8, 8, 0x11);
65 VDUP(vector64_b, , int, s, 16, 4, 0x22);
66 VDUP(vector64_b, , int, s, 32, 2, 0x33);
67 VDUP(vector64_b, , int, s, 64, 1, 0x44);
68 VDUP(vector64_b, , uint, u, 8, 8, 0x55);
69 VDUP(vector64_b, , uint, u, 16, 4, 0x66);
70 VDUP(vector64_b, , uint, u, 32, 2, 0x77);
71 VDUP(vector64_b, , uint, u, 64, 1, 0x88);
72 VDUP(vector64_b, , poly, p, 8, 8, 0x55);
73 VDUP(vector64_b, , poly, p, 16, 4, 0x66);
74 VDUP(vector64_b, , float, f, 32, 2, 3.3f);
78 /* Execute the tests. */
79 TEST_VCOMBINE(int, s, 8, 8, 16);
80 TEST_VCOMBINE(int, s, 16, 4, 8);
81 TEST_VCOMBINE(int, s, 32, 2, 4);
82 TEST_VCOMBINE(int, s, 64, 1, 2);
83 TEST_VCOMBINE(uint, u, 8, 8, 16);
84 TEST_VCOMBINE(uint, u, 16, 4, 8);
85 TEST_VCOMBINE(uint, u, 32, 2, 4);
86 TEST_VCOMBINE(uint, u, 64, 1, 2);
87 TEST_VCOMBINE(poly, p, 8, 8, 16);
88 TEST_VCOMBINE(poly, p, 16, 4, 8);
89 TEST_VCOMBINE(float, f, 32, 2, 4);
91 CHECK_RESULTS (TEST_MSG, "");