13 .macro test_ftoi_ex op, r0, fr0, v, c, r, sr
30 .macro test_ftoi op, r0, fr0, v, c, r, sr
33 test_ftoi_ex \op, \r0, \fr0, \v, \c, \r, \sr
36 test_ftoi_ex \op, \r0, \fr0, \v, \c, \r, \sr
40 .macro test_itof_ex op, fr0, ar0, v, c, r, sr
59 .macro test_itof_rm op, fr0, ar0, v, c, rm, r, sr
62 test_itof_ex \op, \fr0, \ar0, \v, \c, \r, \sr
65 test_itof_ex \op, \fr0, \ar0, \v, \c, \r, \sr
68 .macro test_itof op, fr0, ar0, v, c, r0, r1, r2, r3, sr
69 test_itof_rm \op, \fr0, \ar0, \v, \c, 0, \r0, \sr
70 test_itof_rm \op, \fr0, \ar0, \v, \c, 1, \r1, \sr
71 test_itof_rm \op, \fr0, \ar0, \v, \c, 2, \r2, \sr
72 test_itof_rm \op, \fr0, \ar0, \v, \c, 3, \r3, \sr
80 test_ftoi round.s, a2, f0, 0xffc00001, 0, 0x7fffffff, FSR_V
81 test_ftoi round.s, a2, f0, 0xff800001, 0, 0x7fffffff, FSR_V
84 test_ftoi round.s, a2, f0, 0xff800000, 0, 0x80000000, FSR_V
86 /* negative overflow */
87 test_ftoi round.s, a2, f0, 0xceffffff, 1, 0x80000000, FSR_V
88 test_ftoi round.s, a2, f0, 0xcf000000, 0, 0x80000000, FSR__
89 test_ftoi round.s, a2, f0, 0xceffffff, 0, 0x80000080, FSR__
92 test_ftoi round.s, a2, f0, 0xbfa00000, 1, -2, FSR_I /* -1.25 * 2 */
93 test_ftoi round.s, a2, f0, 0xbfc00000, 0, -2, FSR_I /* -1.5 */
94 test_ftoi round.s, a2, f0, 0xbf800000, 1, -2, FSR__ /* -1 * 2 */
95 test_ftoi round.s, a2, f0, 0xbf800000, 0, -1, FSR__ /* -1 */
96 test_ftoi round.s, a2, f0, 0xbf400000, 0, -1, FSR_I /* -0.75 */
97 test_ftoi round.s, a2, f0, 0xbf000000, 0, 0, FSR_I /* -0.5 */
100 test_ftoi round.s, a2, f0, 0x3f000000, 0, 0, FSR_I /* 0.5 */
101 test_ftoi round.s, a2, f0, 0x3f400000, 0, 1, FSR_I /* 0.75 */
102 test_ftoi round.s, a2, f0, 0x3f800000, 0, 1, FSR__ /* 1 */
103 test_ftoi round.s, a2, f0, 0x3f800000, 1, 2, FSR__ /* 1 * 2 */
104 test_ftoi round.s, a2, f0, 0x3fc00000, 0, 2, FSR_I /* 1.5 */
105 test_ftoi round.s, a2, f0, 0x3fa00000, 1, 2, FSR_I /* 1.25 * 2 */
107 /* positive overflow */
108 test_ftoi round.s, a2, f0, 0x4effffff, 0, 0x7fffff80, FSR__
109 test_ftoi round.s, a2, f0, 0x4f000000, 0, 0x7fffffff, FSR_V
110 test_ftoi round.s, a2, f0, 0x4effffff, 1, 0x7fffffff, FSR_V
113 test_ftoi round.s, a2, f0, 0x7f800000, 0, 0x7fffffff, FSR_V
116 test_ftoi round.s, a2, f0, 0x7f800001, 0, 0x7fffffff, FSR_V
117 test_ftoi round.s, a2, f0, 0x7fc00000, 0, 0x7fffffff, FSR_V
122 test_ftoi trunc.s, a2, f0, 0xffc00001, 0, 0x7fffffff, FSR_V
123 test_ftoi trunc.s, a2, f0, 0xff800001, 0, 0x7fffffff, FSR_V
126 test_ftoi trunc.s, a2, f0, 0xff800000, 0, 0x80000000, FSR_V
128 /* negative overflow */
129 test_ftoi trunc.s, a2, f0, 0xceffffff, 1, 0x80000000, FSR_V
130 test_ftoi trunc.s, a2, f0, 0xcf000000, 0, 0x80000000, FSR__
131 test_ftoi trunc.s, a2, f0, 0xceffffff, 0, 0x80000080, FSR__
134 test_ftoi trunc.s, a2, f0, 0xbfa00000, 1, -2, FSR_I /* -1.25 * 2 */
135 test_ftoi trunc.s, a2, f0, 0xbfc00000, 0, -1, FSR_I /* -1.5 */
136 test_ftoi trunc.s, a2, f0, 0xbf800000, 1, -2, FSR__ /* -1 * 2 */
137 test_ftoi trunc.s, a2, f0, 0xbf800000, 0, -1, FSR__ /* -1 */
138 test_ftoi trunc.s, a2, f0, 0xbf400000, 0, 0, FSR_I /* -0.75 */
139 test_ftoi trunc.s, a2, f0, 0xbf000000, 0, 0, FSR_I /* -0.5 */
142 test_ftoi trunc.s, a2, f0, 0x3f000000, 0, 0, FSR_I /* 0.5 */
143 test_ftoi trunc.s, a2, f0, 0x3f400000, 0, 0, FSR_I /* 0.75 */
144 test_ftoi trunc.s, a2, f0, 0x3f800000, 0, 1, FSR__ /* 1 */
145 test_ftoi trunc.s, a2, f0, 0x3f800000, 1, 2, FSR__ /* 1 * 2 */
146 test_ftoi trunc.s, a2, f0, 0x3fc00000, 0, 1, FSR_I /* 1.5 */
147 test_ftoi trunc.s, a2, f0, 0x3fa00000, 1, 2, FSR_I /* 1.25 * 2 */
149 /* positive overflow */
150 test_ftoi trunc.s, a2, f0, 0x4effffff, 0, 0x7fffff80, FSR__
151 test_ftoi trunc.s, a2, f0, 0x4f000000, 0, 0x7fffffff, FSR_V
152 test_ftoi trunc.s, a2, f0, 0x4effffff, 1, 0x7fffffff, FSR_V
155 test_ftoi trunc.s, a2, f0, 0x7f800000, 0, 0x7fffffff, FSR_V
158 test_ftoi trunc.s, a2, f0, 0x7f800001, 0, 0x7fffffff, FSR_V
159 test_ftoi trunc.s, a2, f0, 0x7fc00000, 0, 0x7fffffff, FSR_V
164 test_ftoi floor.s, a2, f0, 0xffc00001, 0, 0x7fffffff, FSR_V
165 test_ftoi floor.s, a2, f0, 0xff800001, 0, 0x7fffffff, FSR_V
168 test_ftoi floor.s, a2, f0, 0xff800000, 0, 0x80000000, FSR_V
170 /* negative overflow */
171 test_ftoi floor.s, a2, f0, 0xceffffff, 1, 0x80000000, FSR_V
172 test_ftoi floor.s, a2, f0, 0xcf000000, 0, 0x80000000, FSR__
173 test_ftoi floor.s, a2, f0, 0xceffffff, 0, 0x80000080, FSR__
176 test_ftoi floor.s, a2, f0, 0xbfa00000, 1, -3, FSR_I /* -1.25 * 2 */
177 test_ftoi floor.s, a2, f0, 0xbfc00000, 0, -2, FSR_I /* -1.5 */
178 test_ftoi floor.s, a2, f0, 0xbf800000, 1, -2, FSR__ /* -1 * 2 */
179 test_ftoi floor.s, a2, f0, 0xbf800000, 0, -1, FSR__ /* -1 */
180 test_ftoi floor.s, a2, f0, 0xbf400000, 0, -1, FSR_I /* -0.75 */
181 test_ftoi floor.s, a2, f0, 0xbf000000, 0, -1, FSR_I /* -0.5 */
184 test_ftoi floor.s, a2, f0, 0x3f000000, 0, 0, FSR_I /* 0.5 */
185 test_ftoi floor.s, a2, f0, 0x3f400000, 0, 0, FSR_I /* 0.75 */
186 test_ftoi floor.s, a2, f0, 0x3f800000, 0, 1, FSR__ /* 1 */
187 test_ftoi floor.s, a2, f0, 0x3f800000, 1, 2, FSR__ /* 1 * 2 */
188 test_ftoi floor.s, a2, f0, 0x3fc00000, 0, 1, FSR_I /* 1.5 */
189 test_ftoi floor.s, a2, f0, 0x3fa00000, 1, 2, FSR_I /* 1.25 * 2 */
191 /* positive overflow */
192 test_ftoi floor.s, a2, f0, 0x4effffff, 0, 0x7fffff80, FSR__
193 test_ftoi floor.s, a2, f0, 0x4f000000, 0, 0x7fffffff, FSR_V
194 test_ftoi floor.s, a2, f0, 0x4effffff, 1, 0x7fffffff, FSR_V
197 test_ftoi floor.s, a2, f0, 0x7f800000, 0, 0x7fffffff, FSR_V
200 test_ftoi floor.s, a2, f0, 0x7f800001, 0, 0x7fffffff, FSR_V
201 test_ftoi floor.s, a2, f0, 0x7fc00000, 0, 0x7fffffff, FSR_V
206 test_ftoi ceil.s, a2, f0, 0xffc00001, 0, 0x7fffffff, FSR_V
207 test_ftoi ceil.s, a2, f0, 0xff800001, 0, 0x7fffffff, FSR_V
210 test_ftoi ceil.s, a2, f0, 0xff800000, 0, 0x80000000, FSR_V
212 /* negative overflow */
213 test_ftoi ceil.s, a2, f0, 0xceffffff, 1, 0x80000000, FSR_V
214 test_ftoi ceil.s, a2, f0, 0xcf000000, 0, 0x80000000, FSR__
215 test_ftoi ceil.s, a2, f0, 0xceffffff, 0, 0x80000080, FSR__
218 test_ftoi ceil.s, a2, f0, 0xbfa00000, 1, -2, FSR_I /* -1.25 * 2 */
219 test_ftoi ceil.s, a2, f0, 0xbfc00000, 0, -1, FSR_I /* -1.5 */
220 test_ftoi ceil.s, a2, f0, 0xbf800000, 1, -2, FSR__ /* -1 * 2 */
221 test_ftoi ceil.s, a2, f0, 0xbf800000, 0, -1, FSR__ /* -1 */
222 test_ftoi ceil.s, a2, f0, 0xbf400000, 0, 0, FSR_I /* -0.75 */
223 test_ftoi ceil.s, a2, f0, 0xbf000000, 0, 0, FSR_I /* -0.5 */
226 test_ftoi ceil.s, a2, f0, 0x3f000000, 0, 1, FSR_I /* 0.5 */
227 test_ftoi ceil.s, a2, f0, 0x3f400000, 0, 1, FSR_I /* 0.75 */
228 test_ftoi ceil.s, a2, f0, 0x3f800000, 0, 1, FSR__ /* 1 */
229 test_ftoi ceil.s, a2, f0, 0x3f800000, 1, 2, FSR__ /* 1 * 2 */
230 test_ftoi ceil.s, a2, f0, 0x3fc00000, 0, 2, FSR_I /* 1.5 */
231 test_ftoi ceil.s, a2, f0, 0x3fa00000, 1, 3, FSR_I /* 1.25 * 2 */
233 /* positive overflow */
234 test_ftoi ceil.s, a2, f0, 0x4effffff, 0, 0x7fffff80, FSR__
235 test_ftoi ceil.s, a2, f0, 0x4f000000, 0, 0x7fffffff, FSR_V
236 test_ftoi ceil.s, a2, f0, 0x4effffff, 1, 0x7fffffff, FSR_V
239 test_ftoi ceil.s, a2, f0, 0x7f800000, 0, 0x7fffffff, FSR_V
242 test_ftoi ceil.s, a2, f0, 0x7f800001, 0, 0x7fffffff, FSR_V
243 test_ftoi ceil.s, a2, f0, 0x7fc00000, 0, 0x7fffffff, FSR_V
248 test_ftoi utrunc.s, a2, f0, 0xffc00001, 0, 0xffffffff, FSR_V
249 test_ftoi utrunc.s, a2, f0, 0xff800001, 0, 0xffffffff, FSR_V
252 test_ftoi utrunc.s, a2, f0, 0xff800000, 0, 0x80000000, FSR_V
254 /* negative overflow */
255 test_ftoi utrunc.s, a2, f0, 0xceffffff, 1, 0x80000000, FSR_V
256 test_ftoi utrunc.s, a2, f0, 0xcf000000, 0, 0x80000000, FSR_V
257 test_ftoi utrunc.s, a2, f0, 0xceffffff, 0, 0x80000080, FSR_V
260 test_ftoi utrunc.s, a2, f0, 0xbfa00000, 1, -2, FSR_V /* -1.25 * 2 */
261 test_ftoi utrunc.s, a2, f0, 0xbfc00000, 0, -1, FSR_V /* -1.5 */
262 test_ftoi utrunc.s, a2, f0, 0xbf800000, 1, -2, FSR_V /* -1 * 2 */
263 test_ftoi utrunc.s, a2, f0, 0xbf800000, 0, -1, FSR_V /* -1 */
264 test_ftoi utrunc.s, a2, f0, 0xbf400000, 0, 0, FSR_I /* -0.75 */
265 test_ftoi utrunc.s, a2, f0, 0xbf000000, 0, 0, FSR_I /* -0.5 */
268 test_ftoi utrunc.s, a2, f0, 0x3f000000, 0, 0, FSR_I /* 0.5 */
269 test_ftoi utrunc.s, a2, f0, 0x3f400000, 0, 0, FSR_I /* 0.75 */
270 test_ftoi utrunc.s, a2, f0, 0x3f800000, 0, 1, FSR__ /* 1 */
271 test_ftoi utrunc.s, a2, f0, 0x3f800000, 1, 2, FSR__ /* 1 * 2 */
272 test_ftoi utrunc.s, a2, f0, 0x3fc00000, 0, 1, FSR_I /* 1.5 */
273 test_ftoi utrunc.s, a2, f0, 0x3fa00000, 1, 2, FSR_I /* 1.25 * 2 */
275 /* positive overflow */
276 test_ftoi utrunc.s, a2, f0, 0x4effffff, 0, 0x7fffff80, FSR__
277 test_ftoi utrunc.s, a2, f0, 0x4f000000, 0, 0x80000000, FSR__
278 test_ftoi utrunc.s, a2, f0, 0x4effffff, 1, 0xffffff00, FSR__
279 test_ftoi utrunc.s, a2, f0, 0x4f800000, 1, 0xffffffff, FSR_V
282 test_ftoi utrunc.s, a2, f0, 0x7f800000, 0, 0xffffffff, FSR_V
285 test_ftoi utrunc.s, a2, f0, 0x7f800001, 0, 0xffffffff, FSR_V
286 test_ftoi utrunc.s, a2, f0, 0x7fc00000, 0, 0xffffffff, FSR_V
290 test_itof float.s, f0, a2, -1, 0, \
291 0xbf800000, 0xbf800000, 0xbf800000, 0xbf800000, FSR__
292 test_itof float.s, f0, a2, 0, 0, 0, 0, 0, 0, FSR__
293 test_itof float.s, f0, a2, 1, 1, \
294 0x3f000000, 0x3f000000, 0x3f000000, 0x3f000000, FSR__
295 test_itof float.s, f0, a2, 1, 0, \
296 0x3f800000, 0x3f800000, 0x3f800000, 0x3f800000, FSR__
297 test_itof float.s, f0, a2, 0x7fffffff, 0, \
298 0x4f000000, 0x4effffff, 0x4f000000, 0x4effffff, FSR_I
302 test_itof ufloat.s, f0, a2, 0, 0, 0, 0, 0, 0, FSR__
303 test_itof ufloat.s, f0, a2, 1, 1, \
304 0x3f000000, 0x3f000000, 0x3f000000, 0x3f000000, FSR__
305 test_itof ufloat.s, f0, a2, 1, 0, \
306 0x3f800000, 0x3f800000, 0x3f800000, 0x3f800000, FSR__
307 test_itof ufloat.s, f0, a2, 0x7fffffff, 0, \
308 0x4f000000, 0x4effffff, 0x4f000000, 0x4effffff, FSR_I
309 test_itof ufloat.s, f0, a2, 0xffffffff, 0, \
310 0x4f800000, 0x4f7fffff, 0x4f800000, 0x4f7fffff, FSR_I