about summary refs log tree commit diff stats
diff options
context:
space:
mode:
authorFabrice Bellard <fabrice@bellard.org>2024-02-03 15:48:57 +0100
committerbptato <nincsnevem662@gmail.com>2024-03-02 18:12:23 +0100
commit58440e5b3714bf37c19a37c24029d398e573ed19 (patch)
treedba34dc4cd186b497a323a1935a9388fa0a4a21b
parent600cee2b429c3e9a206de8c963aeddb5f9210823 (diff)
downloadchawan-58440e5b3714bf37c19a37c24029d398e573ed19.tar.gz
avoid using INT64_MAX in double comparisons because it cannot be exactly represented as a double (bnoordhuis)
-rw-r--r--lib/quickjs/quickjs.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/lib/quickjs/quickjs.c b/lib/quickjs/quickjs.c
index 2348108d..e18ba484 100644
--- a/lib/quickjs/quickjs.c
+++ b/lib/quickjs/quickjs.c
@@ -10873,7 +10873,7 @@ static int JS_ToInt64SatFree(JSContext *ctx, int64_t *pres, JSValue val)
             } else {
                 if (d < INT64_MIN)
                     *pres = INT64_MIN;
-                else if (d > INT64_MAX)
+                else if (d >= 0x1p63) /* must use INT64_MAX + 1 because INT64_MAX cannot be exactly represented as a double */
                     *pres = INT64_MAX;
                 else
                     *pres = (int64_t)d;
@@ -55458,7 +55458,8 @@ static JSValue js_atomics_wait(JSContext *ctx,
     }
     if (JS_ToFloat64(ctx, &d, argv[3]))
         return JS_EXCEPTION;
-    if (isnan(d) || d > INT64_MAX)
+    /* must use INT64_MAX + 1 because INT64_MAX cannot be exactly represented as a double */
+    if (isnan(d) || d >= 0x1p63)
         timeout = INT64_MAX;
     else if (d < 0)
         timeout = 0;