diff options
-rwxr-xr-x | Configure | 17 | ||||
-rw-r--r-- | Cross/config.sh-arm-linux | 1 | ||||
-rw-r--r-- | NetWare/config.wc | 1 | ||||
-rw-r--r-- | Porting/Glossary | 4 | ||||
-rw-r--r-- | Porting/config.sh | 1 | ||||
-rwxr-xr-x | config_h.SH | 7 | ||||
-rw-r--r-- | configure.com | 5 | ||||
-rw-r--r-- | perl.h | 39 | ||||
-rw-r--r-- | plan9/config_sh.sample | 1 | ||||
-rw-r--r-- | symbian/config.sh | 1 | ||||
-rw-r--r-- | uconfig.sh | 1 | ||||
-rw-r--r-- | uconfig64.sh | 1 | ||||
-rw-r--r-- | win32/config.ce | 1 | ||||
-rw-r--r-- | win32/config.gc | 1 | ||||
-rw-r--r-- | win32/config.vc | 1 |
15 files changed, 55 insertions, 27 deletions
@@ -1180,6 +1180,7 @@ ivsize='' ivtype='' nv_overflows_integers_at='' nv_preserves_uv_bits='' +nvmantbits='' nvsize='' nvtype='' u16size='' @@ -18834,6 +18835,21 @@ else fi $rm_try +$echo "Checking how many mantissa bits your NVs have..." >&4 +if test "X$usequadmath" = "X$define"; then + nvmantbits=112 # 128-1-15 +else + if test "X$nvsize" = "X$doublesize"; then + nvmantbits="$doublemantbits" + else + if test "X$nvsize" = "X$longdblsize"; then + nvmantbits="$longdblmantbits" + else + nvmantbits="$undef" + fi + fi +fi + : see if sigprocmask exists set sigprocmask d_sigprocmask eval $inlibc @@ -24840,6 +24856,7 @@ nv_preserves_uv_bits='$nv_preserves_uv_bits' nveformat='$nveformat' nvfformat='$nvfformat' nvgformat='$nvgformat' +nvmantbits='$nvmantbits' nvsize='$nvsize' nvtype='$nvtype' o_nonblock='$o_nonblock' diff --git a/Cross/config.sh-arm-linux b/Cross/config.sh-arm-linux index 544efd1f94..3d1eb4dabf 100644 --- a/Cross/config.sh-arm-linux +++ b/Cross/config.sh-arm-linux @@ -913,6 +913,7 @@ nv_preserves_uv_bits='32' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/NetWare/config.wc b/NetWare/config.wc index 0e7a6826dd..e70b4dfd16 100644 --- a/NetWare/config.wc +++ b/NetWare/config.wc @@ -888,6 +888,7 @@ nv_preserves_uv_bits='32' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/Porting/Glossary b/Porting/Glossary index ab63d53a0a..2cd4bb38c2 100644 --- a/Porting/Glossary +++ b/Porting/Glossary @@ -4382,6 +4382,10 @@ nvGUformat (perlxvf.U): This variable contains the format string used for printing a Perl NV using %G-ish floating point format. +nvmantbits (mantbits.U): + This variable tells how many bits the mantissa of a Perl NV has, + not including the possible implicit bit. + nvsize (perlxv.U): This variable is the size of a Perl NV in bytes. Note that some floating point formats have unused bytes. diff --git a/Porting/config.sh b/Porting/config.sh index 88b0b815e3..93b2a6c90e 100644 --- a/Porting/config.sh +++ b/Porting/config.sh @@ -931,6 +931,7 @@ nv_preserves_uv_bits='53' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/config_h.SH b/config_h.SH index 6ae8fe2394..0701a42141 100755 --- a/config_h.SH +++ b/config_h.SH @@ -4877,6 +4877,13 @@ sed <<!GROK!THIS! >$CONFIG_H -e 's!^#undef\(.*/\)\*!/\*#define\1 \*!' -e 's!^#un */ #define LONGDBLMANTBITS $longdblmantbits +/* NVMANTBITS: + * This symbol, if defined, tells how many mantissa bits + * (not including implicit bit) there are in a Perl NV. + * This depends on which floating point type was chosen. + */ +#define NVMANTBITS $nvmantbits /**/ + /* NEED_VA_COPY: * This symbol, if defined, indicates that the system stores * the variable argument list datatype, va_list, in a format diff --git a/configure.com b/configure.com index 6e05e90ddb..a136a77c4e 100644 --- a/configure.com +++ b/configure.com @@ -5579,6 +5579,9 @@ $ doublemantbits = "52" $ IF uselongdouble .OR. uselongdouble .EQS. "define" $ THEN $ nvtype="long double" +$ nvmantbits = longdblmantbits +$ ELSE +$ nvmantbits = doublemantbits $ ENDIF $! $ tmp = "''ivtype'" @@ -6660,6 +6663,7 @@ $ WC "longdblsize='" + longdblsize + "'" $ WC "longdblkind='" + longdblkind + "'" $ WC "longdblinfbytes='" + longdblinfbytes + "'" $ WC "longdblnanbytes='" + longdblnanbytes + "'" +$ WC "longdblmantbits='" + longdblmantbits + "'" $ WC "longlongsize='" + longlongsize + "'" $ WC "longsize='" + longsize + "'" $ IF uselargefiles .OR. uselargefiles .EQS. "define" @@ -6695,6 +6699,7 @@ $ WC "nvfformat='" + nvfformat + "'" $ WC "nvFUformat='" + nvFUformat + "'" $ WC "nvgformat='" + nvgformat + "'" $ WC "nvGUformat='" + nvGUformat + "'" +$ WC "nvmantbits='" + nvmantbits + "'" $ WC "nvsize='" + nvsize + "'" $ WC "nvtype='" + nvtype + "'" $ WC "o_nonblock=' '" @@ -6630,21 +6630,6 @@ extern void moncontrol(int); # endif #endif -/* NV_MANT_BITS is the number of _real_ mantissa bits in an NV. - * For the standard IEEE 754 fp this number is usually one less that - * *DBL_MANT_DIG because of the implicit (aka hidden) bit, which isn't - * real. For the 80-bit extended precision formats (x86*), the number - * of mantissa bits... depends. For normal floats, it's 64. But for - * the inf/nan, it's different (zero for inf, 61 for nan). - * NV_MANT_BITS works for normal floats. */ -#ifdef USE_QUADMATH /* IEEE 754 128-bit */ -# define NV_MANT_BITS (FLT128_MANT_DIG - 1) -#elif NVSIZE == DOUBLESIZE -# define NV_MANT_BITS DOUBLEMANTBITS -#elif NVSIZE == LONG_DOUBLESIZE -# define NV_MANT_BITS LONGDBLMANTBITS -#endif - /* NaNs (not-a-numbers) can carry payload bits, in addition to * "nan-ness". Part of the payload is the quiet/signaling bit. * To back up a bit (harhar): @@ -6691,15 +6676,16 @@ extern void moncontrol(int); * This means that in this format there are 61 bits available * for the nan payload. * - * NV_NAN_PAYLOAD_BITS tells how many bits there are available for - * the nan payload, *not* including the quiet/signaling bit. */ -#if defined(USE_LONG_DOUBLE) && NVSIZE > DOUBLESIZE && \ - (LONG_DOUBLEKIND == LONG_DOUBLE_IS_X86_80_BIT_LITTLE_ENDIAN || \ - LONG_DOUBLEKIND == LONG_DOUBLE_IS_X86_80_BIT_BIG_ENDIAN) -# define NV_NAN_PAYLOAD_BITS 61 -#else -# define NV_NAN_PAYLOAD_BITS (NV_MANT_BITS - 1) -#endif + * NVMANTBITS is the number of _real_ mantissa bits in an NV. + * For the standard IEEE 754 fp this number is usually one less that + * *DBL_MANT_DIG because of the implicit (aka hidden) bit, which isn't + * real. For the 80-bit extended precision formats (x86*), the number + * of mantissa bits... depends. For normal floats, it's 64. But for + * the inf/nan, it's different (zero for inf, 61 for nan). + * NVMANTBITS works for normal floats. */ + +/* We do not want to include the quiet/signaling bit. */ +#define NV_NAN_BITS (NVMANTBITS - 1) #if defined(USE_LONG_DOUBLE) && NVSIZE > DOUBLESIZE # if LONG_DOUBLEKIND == LONG_DOUBLE_IS_IEEE_754_128_BIT_LITTLE_ENDIAN @@ -6757,10 +6743,9 @@ extern void moncontrol(int); #elif defined(USE_LONG_DOUBLE) && \ (LONG_DOUBLEKIND == LONG_DOUBLE_IS_DOUBLEDOUBLE_128_BIT_LITTLE_ENDIAN || \ LONG_DOUBLEKIND == LONG_DOUBLE_IS_DOUBLEDOUBLE_128_BIT_BIG_ENDIAN) -# define NV_NAN_QS_BIT_SHIFT 3 /* 0x08, but not via NV_NAN_PAYLOAD_BITS */ +# define NV_NAN_QS_BIT_SHIFT 3 /* 0x08, but not via NV_NAN_BITS */ #else -# define NV_NAN_QS_BIT_SHIFT \ - ((NV_NAN_PAYLOAD_BITS) % 8) /* usually 3, or 0x08 */ +# define NV_NAN_QS_BIT_SHIFT ((NV_NAN_BITS) % 8) /* usually 3, or 0x08 */ #endif #define NV_NAN_QS_BIT (1 << (NV_NAN_QS_BIT_SHIFT)) /* NV_NAN_QS_BIT_OFFSET is the bit offset from the beginning of a NV diff --git a/plan9/config_sh.sample b/plan9/config_sh.sample index 7dce0deb06..7fd970da62 100644 --- a/plan9/config_sh.sample +++ b/plan9/config_sh.sample @@ -894,6 +894,7 @@ nv_preserves_uv_bits='31' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/symbian/config.sh b/symbian/config.sh index 27f2e588af..a5aa4779a0 100644 --- a/symbian/config.sh +++ b/symbian/config.sh @@ -763,6 +763,7 @@ nv_preserves_uv_bits='0' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/uconfig.sh b/uconfig.sh index 0278020ddf..bd889e30f9 100644 --- a/uconfig.sh +++ b/uconfig.sh @@ -737,6 +737,7 @@ nv_preserves_uv_bits='0' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/uconfig64.sh b/uconfig64.sh index 2fefaff234..ec09c1e2f8 100644 --- a/uconfig64.sh +++ b/uconfig64.sh @@ -738,6 +738,7 @@ nv_preserves_uv_bits='0' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/win32/config.ce b/win32/config.ce index 7ee16c6ef9..3c10d778d7 100644 --- a/win32/config.ce +++ b/win32/config.ce @@ -877,6 +877,7 @@ nv_preserves_uv_bits='32' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/win32/config.gc b/win32/config.gc index f34d8ec4f7..e0eb2382b6 100644 --- a/win32/config.gc +++ b/win32/config.gc @@ -906,6 +906,7 @@ nv_preserves_uv_bits='32' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' diff --git a/win32/config.vc b/win32/config.vc index 549c14097b..b4efd32b1b 100644 --- a/win32/config.vc +++ b/win32/config.vc @@ -905,6 +905,7 @@ nv_preserves_uv_bits='32' nveformat='"e"' nvfformat='"f"' nvgformat='"g"' +nvmantbits='52' nvsize='8' nvtype='double' o_nonblock='O_NONBLOCK' |