Bug 385411 s390x: Tests and internals for z13 vector FP support
[valgrind.git] / none / tests / s390x / vector_float.c
blob52f3a296f562dad4f9993e6c3579a08df6627f75
1 #include "vector.h"
3 #define s390_generate_float_test(insn, asm_string) \
4 s390_test_generate(v##insn##00, "v" #insn " " asm_string ",0, 0") \
5 s390_test_generate(v##insn##01, "v" #insn " " asm_string ",0, 1") \
6 s390_test_generate(v##insn##03, "v" #insn " " asm_string ",0, 3") \
7 s390_test_generate(v##insn##04, "v" #insn " " asm_string ",0, 4") \
8 s390_test_generate(v##insn##05, "v" #insn " " asm_string ",0, 5") \
9 s390_test_generate(v##insn##06, "v" #insn " " asm_string ",0, 6") \
10 s390_test_generate(v##insn##07, "v" #insn " " asm_string ",0, 7") \
11 s390_test_generate(w##insn##00, "w" #insn " " asm_string ",0, 0") \
12 s390_test_generate(w##insn##01, "w" #insn " " asm_string ",0, 1") \
13 s390_test_generate(w##insn##03, "w" #insn " " asm_string ",0, 3") \
14 s390_test_generate(w##insn##04, "w" #insn " " asm_string ",0, 4") \
15 s390_test_generate(w##insn##05, "w" #insn " " asm_string ",0, 5") \
16 s390_test_generate(w##insn##06, "w" #insn " " asm_string ",0, 6") \
17 s390_test_generate(w##insn##07, "w" #insn " " asm_string ",0, 7") \
19 #define s390_call_float_test(insn, info) \
20 test_with_selective_printing(v ##insn ## 00, info); \
21 test_with_selective_printing(v ##insn ## 01, info); \
22 test_with_selective_printing(v ##insn ## 03, info); \
23 test_with_selective_printing(v ##insn ## 04, info); \
24 test_with_selective_printing(v ##insn ## 05, info); \
25 test_with_selective_printing(v ##insn ## 06, info); \
26 test_with_selective_printing(v ##insn ## 07, info); \
27 test_with_selective_printing(w ##insn ## 00, info | V128_V_RES_ZERO_ONLY); \
28 test_with_selective_printing(w ##insn ## 01, info | V128_V_RES_ZERO_ONLY); \
29 test_with_selective_printing(w ##insn ## 03, info | V128_V_RES_ZERO_ONLY); \
30 test_with_selective_printing(w ##insn ## 04, info | V128_V_RES_ZERO_ONLY); \
31 test_with_selective_printing(w ##insn ## 05, info | V128_V_RES_ZERO_ONLY); \
32 test_with_selective_printing(w ##insn ## 06, info | V128_V_RES_ZERO_ONLY); \
33 test_with_selective_printing(w ##insn ## 07, info | V128_V_RES_ZERO_ONLY); \
35 s390_generate_float_test(cdgb, " %%v5, %%v1")
36 s390_generate_float_test(cdlgb, " %%v5, %%v1")
37 s390_generate_float_test(cgdb, " %%v5, %%v1")
38 s390_generate_float_test(clgdb, " %%v5, %%v1")
39 s390_generate_float_test(fidb, " %%v5, %%v1")
40 s390_generate_float_test(ledb, " %%v5, %%v1")
42 s390_test_generate(vldeb, "vldeb %%v5, %%v1")
43 s390_test_generate(wldeb, "wldeb %%v5, %%v1")
45 s390_test_generate(vflcdb, "vflcdb %%v5, %%v1")
46 s390_test_generate(wflcdb, "wflcdb %%v5, %%v1")
47 s390_test_generate(vflndb, "vflndb %%v5, %%v1")
48 s390_test_generate(wflndb, "wflndb %%v5, %%v1")
49 s390_test_generate(vflpdb, "vflpdb %%v5, %%v1")
50 s390_test_generate(wflpdb, "wflpdb %%v5, %%v1")
52 s390_test_generate(vfadb, "vfadb %%v5, %%v1, %%v2")
53 s390_test_generate(wfadb, "wfadb %%v5, %%v1, %%v2")
54 s390_test_generate(vfsdb, "vfsdb %%v5, %%v1, %%v2")
55 s390_test_generate(wfsdb, "wfsdb %%v5, %%v1, %%v2")
56 s390_test_generate(vfmdb, "vfmdb %%v5, %%v1, %%v2")
57 s390_test_generate(wfmdb, "wfmdb %%v5, %%v1, %%v2")
58 s390_test_generate(vfddb, "vfddb %%v5, %%v1, %%v2")
59 s390_test_generate(wfddb, "wfddb %%v5, %%v1, %%v2")
61 s390_test_generate(vfsqdb, "vfsqdb %%v5, %%v1")
62 s390_test_generate(wfsqdb, "wfsqdb %%v5, %%v1")
64 s390_test_generate(vfmadb, "vfmadb %%v5, %%v1, %%v2, %%v3")
65 s390_test_generate(wfmadb, "wfmadb %%v5, %%v1, %%v2, %%v3")
66 s390_test_generate(vfmsdb, "vfmsdb %%v5, %%v1, %%v2, %%v3")
67 s390_test_generate(wfmsdb, "wfmsdb %%v5, %%v1, %%v2, %%v3")
69 s390_test_generate(wfcdb, "wfcdb %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
70 s390_test_generate(wfkdb, "wfkdb %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
72 s390_test_generate(vfcedb, "vfcedb %%v5, %%v1, %%v2")
73 s390_test_generate(wfcedb, "wfcedb %%v5, %%v1, %%v2")
74 s390_test_generate(vfcedbs, "vfcedbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
75 s390_test_generate(wfcedbs, "wfcedbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
77 s390_test_generate(vfchdb, "vfchdb %%v5, %%v1, %%v2")
78 s390_test_generate(wfchdb, "wfchdb %%v5, %%v1, %%v2")
79 s390_test_generate(vfchdbs, "vfchdbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
80 s390_test_generate(wfchdbs, "wfchdbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
82 s390_test_generate(vfchedb, "vfchedb %%v5, %%v1, %%v2")
83 s390_test_generate(wfchedb, "wfchedb %%v5, %%v1, %%v2")
84 s390_test_generate(vfchedbs, "vfchedbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
85 s390_test_generate(wfchedbs, "wfchedbs %%v5, %%v1, %%v2\n" S390_TEST_PUT_CC_TO_RESULT)
87 s390_test_generate(vftcidb0, "vftcidb %%v5, %%v1, 0 \n" S390_TEST_PUT_CC_TO_RESULT)
88 s390_test_generate(vftcidb1, "vftcidb %%v5, %%v1, 1 \n" S390_TEST_PUT_CC_TO_RESULT)
89 s390_test_generate(vftcidb2, "vftcidb %%v5, %%v1, 2 \n" S390_TEST_PUT_CC_TO_RESULT)
90 s390_test_generate(vftcidb3, "vftcidb %%v5, %%v1, 0 \n" S390_TEST_PUT_CC_TO_RESULT)
91 s390_test_generate(vftcidb4, "vftcidb %%v5, %%v1, 4 \n" S390_TEST_PUT_CC_TO_RESULT)
92 s390_test_generate(vftcidb8, "vftcidb %%v5, %%v1, 8 \n" S390_TEST_PUT_CC_TO_RESULT)
93 s390_test_generate(vftcidb16, "vftcidb %%v5, %%v1, 16 \n" S390_TEST_PUT_CC_TO_RESULT)
94 s390_test_generate(vftcidb32, "vftcidb %%v5, %%v1, 32 \n" S390_TEST_PUT_CC_TO_RESULT)
95 s390_test_generate(vftcidb64, "vftcidb %%v5, %%v1, 64 \n" S390_TEST_PUT_CC_TO_RESULT)
96 s390_test_generate(vftcidb128, "vftcidb %%v5, %%v1, 128 \n" S390_TEST_PUT_CC_TO_RESULT)
97 s390_test_generate(vftcidb256, "vftcidb %%v5, %%v1, 256 \n" S390_TEST_PUT_CC_TO_RESULT)
98 s390_test_generate(vftcidb512, "vftcidb %%v5, %%v1, 512 \n" S390_TEST_PUT_CC_TO_RESULT)
99 s390_test_generate(vftcidb1024, "vftcidb %%v5, %%v1, 1024\n" S390_TEST_PUT_CC_TO_RESULT)
100 s390_test_generate(vftcidb2048, "vftcidb %%v5, %%v1, 2048\n" S390_TEST_PUT_CC_TO_RESULT)
102 int main()
104 size_t iteration = 0;
106 s390_call_float_test(cdgb, (V128_V_RES_AS_FLOAT64 | V128_V_ARG1_AS_INT));
107 s390_call_float_test(cdlgb, (V128_V_RES_AS_FLOAT64 | V128_V_ARG1_AS_INT));
108 s390_call_float_test(cgdb, (V128_V_RES_AS_INT | V128_V_ARG1_AS_FLOAT64));
109 s390_call_float_test(clgdb, (V128_V_RES_AS_INT | V128_V_ARG1_AS_FLOAT64));
110 s390_call_float_test(fidb, (V128_V_RES_AS_FLOAT64 | V128_V_ARG1_AS_FLOAT64));
111 s390_call_float_test(ledb, (V128_V_RES_AS_FLOAT32 | V128_V_RES_EVEN_ONLY |
112 V128_V_ARG1_AS_FLOAT64));
114 test_with_selective_printing(vldeb, (V128_V_RES_AS_FLOAT64 |
115 V128_V_ARG1_AS_FLOAT64));
116 test_with_selective_printing(wldeb, (V128_V_RES_AS_FLOAT64 |
117 V128_V_ARG1_AS_FLOAT64));
119 test_with_selective_printing(vflcdb, (V128_V_RES_AS_FLOAT64 |
120 V128_V_ARG1_AS_FLOAT64));
121 test_with_selective_printing(wflcdb, (V128_V_RES_AS_FLOAT64 |
122 V128_V_ARG1_AS_FLOAT64));
123 test_with_selective_printing(vflndb, (V128_V_RES_AS_FLOAT64 |
124 V128_V_ARG1_AS_FLOAT64));
125 test_with_selective_printing(wflndb, (V128_V_RES_AS_FLOAT64 |
126 V128_V_ARG1_AS_FLOAT64));
127 test_with_selective_printing(vflpdb, (V128_V_RES_AS_FLOAT64 |
128 V128_V_ARG1_AS_FLOAT64));
129 test_with_selective_printing(wflpdb, (V128_V_RES_AS_FLOAT64 |
130 V128_V_ARG1_AS_FLOAT64));
132 test_with_selective_printing(vfadb, (V128_V_RES_AS_FLOAT64 |
133 V128_V_ARG1_AS_FLOAT64 |
134 V128_V_ARG2_AS_FLOAT64));
135 test_with_selective_printing(wfadb, (V128_V_RES_AS_FLOAT64 |
136 V128_V_ARG1_AS_FLOAT64 |
137 V128_V_ARG2_AS_FLOAT64));
138 test_with_selective_printing(vfsdb, (V128_V_RES_AS_FLOAT64 |
139 V128_V_ARG1_AS_FLOAT64 |
140 V128_V_ARG2_AS_FLOAT64));
141 test_with_selective_printing(wfsdb, (V128_V_RES_AS_FLOAT64 |
142 V128_V_ARG1_AS_FLOAT64 |
143 V128_V_ARG2_AS_FLOAT64));
144 test_with_selective_printing(vfmdb, (V128_V_RES_AS_FLOAT64 |
145 V128_V_ARG1_AS_FLOAT64 |
146 V128_V_ARG2_AS_FLOAT64));
147 test_with_selective_printing(wfmdb, (V128_V_RES_AS_FLOAT64 |
148 V128_V_ARG1_AS_FLOAT64 |
149 V128_V_ARG2_AS_FLOAT64));
150 test_with_selective_printing(vfddb, (V128_V_RES_AS_FLOAT64 |
151 V128_V_ARG1_AS_FLOAT64 |
152 V128_V_ARG2_AS_FLOAT64));
153 test_with_selective_printing(wfddb, (V128_V_RES_AS_FLOAT64 |
154 V128_V_ARG1_AS_FLOAT64 |
155 V128_V_ARG2_AS_FLOAT64));
157 test_with_selective_printing(vfsqdb, (V128_V_RES_AS_FLOAT64 |
158 V128_V_ARG1_AS_FLOAT64));
159 test_with_selective_printing(wfsqdb, (V128_V_RES_AS_FLOAT64 |
160 V128_V_ARG1_AS_FLOAT64));
162 test_with_selective_printing(vfmadb, (V128_V_RES_AS_FLOAT64 |
163 V128_V_ARG1_AS_FLOAT64 |
164 V128_V_ARG2_AS_FLOAT64 |
165 V128_V_ARG3_AS_FLOAT64));
166 test_with_selective_printing(wfmadb, (V128_V_RES_AS_FLOAT64 |
167 V128_V_ARG1_AS_FLOAT64 |
168 V128_V_ARG2_AS_FLOAT64 |
169 V128_V_ARG3_AS_FLOAT64));
170 test_with_selective_printing(vfmsdb, (V128_V_RES_AS_FLOAT64 |
171 V128_V_ARG1_AS_FLOAT64 |
172 V128_V_ARG2_AS_FLOAT64 |
173 V128_V_ARG3_AS_FLOAT64));
174 test_with_selective_printing(wfmsdb, (V128_V_RES_AS_FLOAT64 |
175 V128_V_ARG1_AS_FLOAT64 |
176 V128_V_ARG2_AS_FLOAT64 |
177 V128_V_ARG3_AS_FLOAT64));
179 test_with_selective_printing(wfcdb, (V128_V_ARG1_AS_FLOAT64 |
180 V128_V_ARG2_AS_FLOAT64 |
181 V128_R_RES));
182 test_with_selective_printing(wfkdb, (V128_V_ARG1_AS_FLOAT64 |
183 V128_V_ARG2_AS_FLOAT64 |
184 V128_R_RES));
186 test_with_selective_printing(vfcedb, (V128_V_RES_AS_INT |
187 V128_V_ARG1_AS_FLOAT64 |
188 V128_V_ARG2_AS_FLOAT64));
189 test_with_selective_printing(wfcedb, (V128_V_RES_AS_INT |
190 V128_V_ARG1_AS_FLOAT64 |
191 V128_V_ARG2_AS_FLOAT64));
192 test_with_selective_printing(vfcedbs, (V128_V_RES_AS_INT |
193 V128_V_ARG1_AS_FLOAT64 |
194 V128_V_ARG2_AS_FLOAT64 |
195 V128_R_RES));
196 test_with_selective_printing(wfcedbs, (V128_V_RES_AS_INT |
197 V128_V_ARG1_AS_FLOAT64 |
198 V128_V_ARG2_AS_FLOAT64 |
199 V128_R_RES));
201 test_with_selective_printing(vfchdb, (V128_V_RES_AS_INT |
202 V128_V_ARG1_AS_FLOAT64 |
203 V128_V_ARG2_AS_FLOAT64));
204 test_with_selective_printing(wfchdb, (V128_V_RES_AS_INT |
205 V128_V_ARG1_AS_FLOAT64 |
206 V128_V_ARG2_AS_FLOAT64));
207 test_with_selective_printing(vfchdbs, (V128_V_RES_AS_INT |
208 V128_V_ARG1_AS_FLOAT64 |
209 V128_V_ARG2_AS_FLOAT64 |
210 V128_R_RES));
211 test_with_selective_printing(wfchdbs, (V128_V_RES_AS_INT |
212 V128_V_ARG1_AS_FLOAT64 |
213 V128_V_ARG2_AS_FLOAT64 |
214 V128_R_RES));
216 test_with_selective_printing(vfchedb, (V128_V_RES_AS_INT |
217 V128_V_ARG1_AS_FLOAT64 |
218 V128_V_ARG2_AS_FLOAT64));
219 test_with_selective_printing(wfchedb, (V128_V_RES_AS_INT |
220 V128_V_ARG1_AS_FLOAT64 |
221 V128_V_ARG2_AS_FLOAT64));
222 test_with_selective_printing(vfchedbs, (V128_V_RES_AS_INT |
223 V128_V_ARG1_AS_FLOAT64 |
224 V128_V_ARG2_AS_FLOAT64 |
225 V128_R_RES));
226 test_with_selective_printing(wfchedbs, (V128_V_RES_AS_INT |
227 V128_V_ARG1_AS_FLOAT64 |
228 V128_V_ARG2_AS_FLOAT64 |
229 V128_R_RES));
231 test_with_selective_printing(vftcidb0, (V128_V_RES_AS_INT |
232 V128_V_ARG1_AS_FLOAT64 |
233 V128_R_RES));
234 test_with_selective_printing(vftcidb1, (V128_V_RES_AS_INT |
235 V128_V_ARG1_AS_FLOAT64 |
236 V128_R_RES));
237 test_with_selective_printing(vftcidb2, (V128_V_RES_AS_INT |
238 V128_V_ARG1_AS_FLOAT64 |
239 V128_R_RES));
240 test_with_selective_printing(vftcidb3, (V128_V_RES_AS_INT |
241 V128_V_ARG1_AS_FLOAT64 |
242 V128_R_RES));
243 test_with_selective_printing(vftcidb4, (V128_V_RES_AS_INT |
244 V128_V_ARG1_AS_FLOAT64 |
245 V128_R_RES));
246 test_with_selective_printing(vftcidb8, (V128_V_RES_AS_INT |
247 V128_V_ARG1_AS_FLOAT64 |
248 V128_R_RES));
249 test_with_selective_printing(vftcidb16, (V128_V_RES_AS_INT |
250 V128_V_ARG1_AS_FLOAT64 |
251 V128_R_RES));
252 test_with_selective_printing(vftcidb32, (V128_V_RES_AS_INT |
253 V128_V_ARG1_AS_FLOAT64 |
254 V128_R_RES));
255 test_with_selective_printing(vftcidb64, (V128_V_RES_AS_INT |
256 V128_V_ARG1_AS_FLOAT64 |
257 V128_R_RES));
258 test_with_selective_printing(vftcidb128, (V128_V_RES_AS_INT |
259 V128_V_ARG1_AS_FLOAT64 |
260 V128_R_RES));
261 test_with_selective_printing(vftcidb256, (V128_V_RES_AS_INT |
262 V128_V_ARG1_AS_FLOAT64 |
263 V128_R_RES));
264 test_with_selective_printing(vftcidb512, (V128_V_RES_AS_INT |
265 V128_V_ARG1_AS_FLOAT64 |
266 V128_R_RES));
267 test_with_selective_printing(vftcidb1024, (V128_V_RES_AS_INT |
268 V128_V_ARG1_AS_FLOAT64 |
269 V128_R_RES));
270 test_with_selective_printing(vftcidb2048, (V128_V_RES_AS_INT |
271 V128_V_ARG1_AS_FLOAT64 |
272 V128_R_RES));
274 return 0;