From eb610f14903159e290572361742a3debc8336c3c Mon Sep 17 00:00:00 2001 From: Gavin Hayes Date: Thu, 21 Sep 2023 20:45:57 -0400 Subject: [PATCH 1/3] testlib/showerror.c fix SIGSEGV due to improper use of tinyprint --- libc/testlib/showerror.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/libc/testlib/showerror.c b/libc/testlib/showerror.c index b4ef591609d..737a94661f8 100644 --- a/libc/testlib/showerror.c +++ b/libc/testlib/showerror.c @@ -98,9 +98,9 @@ static void testlib_showerror_(int line, // } if (!isempty(fmt)) { if (_weaken(kvprintf)) { - tinyprint(2, "\t"); + tinyprint(2, "\t", NULL); _weaken(kvprintf)(fmt, va); - tinyprint(2, "\n"); + tinyprint(2, "\n", NULL); } else { tinyprint(2, "\t[missing kvprintf]\n"); } From 0c7dcd90de54d671c3c55b1f2c1a56cd6a19e62c Mon Sep 17 00:00:00 2001 From: Gavin Hayes Date: Thu, 21 Sep 2023 21:10:03 -0400 Subject: [PATCH 2/3] strtod_test, check NaN (without n-char-sequence) and infinity --- test/libc/tinymath/strtod_test.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/test/libc/tinymath/strtod_test.c b/test/libc/tinymath/strtod_test.c index 74b0225b3f9..9305663a3b5 100644 --- a/test/libc/tinymath/strtod_test.c +++ b/test/libc/tinymath/strtod_test.c @@ -38,6 +38,17 @@ static const struct { uint64_t i; const char *s; } V[] = { + {0x7FF8000000000000, "nan"}, // + {0x7FF8000000000000, "NaN"}, // + {0x7FF8000000000000, "NAn"}, // + {0x7FF8000000000000, "nAN"}, // + {0x7FF8000000000000, "NAN"}, // + {0x7FF0000000000000, "INF"}, // + {0x7FF0000000000000, "iNf"}, // + {0x7FF8000000000000, "+NAN"}, // + {0xFFF8000000000000, "-NAN"}, // + {0x7FF0000000000000, "+INF"}, // + {0xFFF0000000000000, "-INF"}, // {0x2fa7b6d71d20b96c, "4e-079"}, // {0x09eb8d7e32be6396, "7e-261"}, // {0x3ae7361cb863de62, "6e-025"}, // @@ -85,6 +96,10 @@ static const struct { {0x7044d64d4079150c, "647e0230"}, // {0x64a7d93193f78fc6, "755e0174"}, // {0x30dcd5bee57763e6, "255e-075"}, // + {0x7FF0000000000000, "INFINITY"}, // + {0x7FF0000000000000, "iNfiNiTy"}, // + {0x7FF0000000000000, "+INFINITY"}, // + {0xFFF0000000000000, "-INFINITY"}, // {0x4c159bd3ad46e346, "3391e0055"}, // {0x3d923d1b5eb1d778, "4147e-015"}, // {0x3b482782afe1869e, "3996e-026"}, // From b00d4c096762021ffe76551389c4247eaa4f9ca1 Mon Sep 17 00:00:00 2001 From: Gavin Hayes Date: Thu, 21 Sep 2023 21:36:59 -0400 Subject: [PATCH 3/3] strtod: handle NaN properly --- third_party/gdtoa/strtod.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/third_party/gdtoa/strtod.c b/third_party/gdtoa/strtod.c index 77e40534275..6597bc061b1 100644 --- a/third_party/gdtoa/strtod.c +++ b/third_party/gdtoa/strtod.c @@ -237,8 +237,8 @@ strtod(const char *s00, char **se) word1(&rv) = bits[0]; } else { - word0(&rv) = NAN_WORD0; - word1(&rv) = NAN_WORD1; + word0(&rv) = 0x7ff80000; + word1(&rv) = 0x0; } goto ret; }