1 /* $NetBSD: infinityl_ieee754.c,v 1.1 2011/01/17 23:53:03 matt Exp $ */
4 * IEEE-compatible infinityl.c for 64-bit or 128-bit long double format.
5 * This is public domain.
9 #if defined(LIBC_SCCS) && !defined(lint)
10 __RCSID("$NetBSD: infinityl_ieee754.c,v 1.1 2011/01/17 23:53:03 matt Exp $");
11 #endif /* LIBC_SCCS and not lint */
14 #include <machine/endian.h>
15 #include <machine/ieee.h>
17 #ifdef __HAVE_LONG_DOUBLE
18 #define LDBL_EXPBITS EXT_EXPBITS
19 #define LDBL_EXP_INFNAN EXT_EXP_INFNAN
21 #define LDBL_EXPBITS DBL_EXPBITS
22 #define LDBL_EXP_INFNAN DBL_EXP_INFNAN
25 #define EXP_INFNAN (LDBL_EXP_INFNAN << (31 - LDBL_EXPBITS))
27 const union __long_double_u __infinityl
= { {
28 #if BYTE_ORDER == BIG_ENDIAN
29 [0] = (EXP_INFNAN
>> 24) & 0x7f,
30 [1] = (EXP_INFNAN
>> 16) & 0xff,
31 [2] = (EXP_INFNAN
>> 8) & 0xff,
32 [3] = (EXP_INFNAN
>> 0) & 0xff,
34 [sizeof(long double)-4] = (EXP_INFNAN
>> 0) & 0xff,
35 [sizeof(long double)-3] = (EXP_INFNAN
>> 8) & 0xff,
36 [sizeof(long double)-2] = (EXP_INFNAN
>> 16) & 0xff,
37 [sizeof(long double)-1] = (EXP_INFNAN
>> 24) & 0x7f,