Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/libc/gdtoa PR/55668: Martin Husemann: Disable optimizati...



details:   https://anonhg.NetBSD.org/src/rev/31ba04a88b78
branches:  trunk
changeset: 1014348:31ba04a88b78
user:      christos <christos%NetBSD.org@localhost>
date:      Fri Sep 18 14:06:45 2020 +0000

description:
PR/55668: Martin Husemann: Disable optimization to avoid infinite loop.
Also bring in a few changes from the most recent gdtoa code (not relevant
to the bug).

diffstat:

 lib/libc/gdtoa/strtod.c |  31 +++++++++++++++----------------
 1 files changed, 15 insertions(+), 16 deletions(-)

diffs (104 lines):

diff -r 7746ae8e86d8 -r 31ba04a88b78 lib/libc/gdtoa/strtod.c
--- a/lib/libc/gdtoa/strtod.c   Fri Sep 18 09:53:50 2020 +0000
+++ b/lib/libc/gdtoa/strtod.c   Fri Sep 18 14:06:45 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: strtod.c,v 1.15 2019/08/01 02:27:43 riastradh Exp $ */
+/* $NetBSD: strtod.c,v 1.16 2020/09/18 14:06:45 christos Exp $ */
 
 /****************************************************************
 
@@ -90,16 +90,16 @@
        }
 #endif /*}*/
 
+#if __GNUC_PREREQ__(9, 3)
+__attribute__((__optimize__("O0")))
+#endif
 static double
 _int_strtod_l(CONST char *s00, char **se, locale_t loc)
 {
 #ifdef Avoid_Underflow
        int scale;
 #endif
-#ifdef INFNAN_CHECK
-       int decpt;
-#endif
-       int bb2, bb5, bbe, bd2, bd5, bbbits, bs2, c, dsign,
+       int bb2, bb5, bbe, bd2, bd5, bbbits, bs2, c, decpt, dsign,
                 e, e1, esign, i, j, k, nd, nd0, nf, nz, nz0, sign;
        CONST char *s, *s0, *s1;
        double aadj;
@@ -133,10 +133,7 @@
 #endif /*}}*/
 #endif /*}*/
 
-#ifdef INFNAN_CHECK
-       decpt = 0;
-#endif
-       sign = nz0 = nz = 0;
+       sign = nz0 = nz = decpt = 0;
        dval(&rv) = 0.;
        for(s = s00;;s++) switch(*s) {
                case '-':
@@ -203,7 +200,7 @@
        for(nd = nf = 0; (c = *s) >= '0' && c <= '9'; nd++, s++)
                if (nd < 9)
                        y = 10*y + c - '0';
-               else if (nd < 16)
+               else if (nd < DBL_DIG + 2)
                        z = 10*z + c - '0';
        nd0 = nd;
 #ifdef USE_LOCALE
@@ -217,9 +214,7 @@
        if (c == '.') {
                c = *++s;
 #endif
-#ifdef INFNAN_CHECK
                decpt = 1;
-#endif
                if (!nd) {
                        for(; c == '0'; c = *++s)
                                nz++;
@@ -239,11 +234,11 @@
                                for(i = 1; i < nz; i++)
                                        if (nd++ < 9)
                                                y *= 10;
-                                       else if (nd <= DBL_DIG + 1)
+                                       else if (nd <= DBL_DIG + 2)
                                                z *= 10;
                                if (nd++ < 9)
                                        y = 10*y + c;
-                               else if (nd <= DBL_DIG + 1)
+                               else if (nd <= DBL_DIG + 2)
                                        z = 10*z + c;
                                nz = 0;
                                }
@@ -344,7 +339,7 @@
 
        if (!nd0)
                nd0 = nd;
-       k = nd < DBL_DIG + 1 ? nd : DBL_DIG + 1;
+       k = nd < DBL_DIG + 2 ? nd : DBL_DIG + 2;
        dval(&rv) = y;
        if (k > 9) {
 #ifdef SET_INEXACT
@@ -555,6 +550,10 @@
                                if (!dval(&rv)) {
  undfl:
                                        dval(&rv) = 0.;
+#ifdef Honor_FLT_ROUNDS
+                                       if (Rounding == 2)
+                                               word1(&rv) = 1;
+#endif
                                        goto range_err;
                                        }
 #ifndef Avoid_Underflow
@@ -977,7 +976,7 @@
 #ifdef Avoid_Underflow
                        if (scale && y <= 2*P*Exp_msk1) {
                                if (aadj <= 0x7fffffff) {
-                                       if ((z = aadj) == 0)
+                                       if ((z = aadj) <= 0)
                                                z = 1;
                                        aadj = z;
                                        dval(&aadj1) = dsign ? aadj : -aadj;



Home | Main Index | Thread Index | Old Index