blob: 1523deaa1d55e4c3c8db95b3c8cd9ca77d4046a1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
/* { dg-do run } */
/* { dg-require-effective-target f16c } */
/* { dg-options "-O2 -mf16c" } */
#include "f16c-check.h"
static void
f16c_test (void)
{
union256 res;
union128i_w val;
float exp[8];
exp[0] = 1;
exp[1] = 2;
exp[2] = 4;
exp[3] = 8;
exp[4] = -1;
exp[5] = -2;
exp[6] = -4;
exp[7] = -8;
val.a[0] = 0x3c00;
val.a[1] = 0x4000;
val.a[2] = 0x4400;
val.a[3] = 0x4800;
val.a[4] = 0xbc00;
val.a[5] = 0xc000;
val.a[6] = 0xc400;
val.a[7] = 0xc800;
res.x = _mm256_cvtph_ps (val.x);
if (check_union256 (res, exp))
abort ();
}
|