1 // RUN: %clang_builtins %s %librt -o %t && %run %t
2 // REQUIRES: librt_has_extendsftf2
7 #if __LDBL_MANT_DIG__ == 113
11 COMPILER_RT_ABI
long double __extendsftf2(float a
);
13 int test__extendsftf2(float a
, uint64_t expectedHi
, uint64_t expectedLo
)
15 long double x
= __extendsftf2(a
);
16 int ret
= compareResultF128(x
, expectedHi
, expectedLo
);
20 printf("error in test__extendsftf2(%f) = %.20Lf, "
21 "expected %.20Lf\n", a
, x
, fromRep128(expectedHi
, expectedLo
));
26 char assumption_1
[sizeof(long double) * CHAR_BIT
== 128] = {0};
32 #if __LDBL_MANT_DIG__ == 113
34 if (test__extendsftf2(makeQNaN32(),
35 UINT64_C(0x7fff800000000000),
39 if (test__extendsftf2(makeNaN32(UINT32_C(0x410000)),
40 UINT64_C(0x7fff820000000000),
44 if (test__extendsftf2(makeInf32(),
45 UINT64_C(0x7fff000000000000),
49 if (test__extendsftf2(0.0f
, UINT64_C(0x0), UINT64_C(0x0)))
52 if (test__extendsftf2(0x1.23456p
+5f
,
53 UINT64_C(0x4004234560000000),
56 if (test__extendsftf2(0x1.edcbap
-9f
,
57 UINT64_C(0x3ff6edcba0000000),
60 if (test__extendsftf2(0x1.23456p
+45f
,
61 UINT64_C(0x402c234560000000),
64 if (test__extendsftf2(0x1.edcbap
-45f
,
65 UINT64_C(0x3fd2edcba0000000),