From: drh Date: Fri, 9 May 2008 03:07:33 +0000 (+0000) Subject: Change the implementation of sqlite3IsNaN() so that it works even if X-Git-Tag: version-3.6.10~1069 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=47d22f6702983f20908f76006b447f336eefd7ca;p=thirdparty%2Fsqlite.git Change the implementation of sqlite3IsNaN() so that it works even if compiled using -ffinite-math-only. Tickets #3101 and #3060. (CVS 5108) FossilOrigin-Name: 19ee2b3324461150d2c1600c67fe604114a1b69f --- diff --git a/manifest b/manifest index c31df8d018..96606f778b 100644 --- a/manifest +++ b/manifest @@ -1,5 +1,5 @@ -C Fix\srecently\sintroduced\sbug\sin\stester.tcl.\s(CVS\s5107) -D 2008-05-08T16:51:12 +C Change\sthe\simplementation\sof\ssqlite3IsNaN()\sso\sthat\sit\sworks\seven\sif\ncompiled\susing\s-ffinite-math-only.\s\sTickets\s#3101\sand\s#3060.\s(CVS\s5108) +D 2008-05-09T03:07:34 F Makefile.arm-wince-mingw32ce-gcc ac5f7b2cef0cd850d6f755ba6ee4ab961b1fadf7 F Makefile.in 8b9b8263852f0217157f9042b8e3dae7427ec739 F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654 @@ -165,7 +165,7 @@ F src/tokenize.c 8d77af8584cf027dc21375f0efa5818cb303c995 F src/trigger.c 9bd3b6fa0beff4a02d262c96466f752ec15a7fc3 F src/update.c 2d7143b9014e955509cc4f323f9a9584fb898f34 F src/utf.c 8c94fa10efc78c2568d08d436acc59df4df7191b -F src/util.c 43a77ab79275991b819428ded8ac8dc868604ac7 +F src/util.c 743a0d5e94eb5a55a38e97a74fc0d5ffaa48a1c0 F src/vacuum.c c3b2b70677f874102b8753bf494c232e777f3998 F src/vdbe.c 2bc3352c8109ef312ea129ae1cbad4c0328c5871 F src/vdbe.h f4bb70962d9c13e0f65b215c90e8acea1ae6e8ee @@ -634,7 +634,7 @@ F www/tclsqlite.tcl 8be95ee6dba05eabcd27a9d91331c803f2ce2130 F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0 F www/version3.tcl 890248cf7b70e60c383b0e84d77d5132b3ead42b F www/whentouse.tcl fc46eae081251c3c181bd79c5faef8195d7991a5 -P 8a99efc07f93bc11d21aa501349c81f0fd8abf7b -R b74d8bc72e0ee5f251e922de4c137ed1 -U danielk1977 -Z 9f6028499912df37de9a263330ef2df9 +P 4b573d4e7dd8c3417cfdebe7d2885de7bdc522db +R 79b226a56001cceb1de45a2f20e236c5 +U drh +Z 36be44822c44ec8dd7529a9a89a5a5cb diff --git a/manifest.uuid b/manifest.uuid index c8a134040e..db78e21635 100644 --- a/manifest.uuid +++ b/manifest.uuid @@ -1 +1 @@ -4b573d4e7dd8c3417cfdebe7d2885de7bdc522db \ No newline at end of file +19ee2b3324461150d2c1600c67fe604114a1b69f \ No newline at end of file diff --git a/src/util.c b/src/util.c index 46dc5cb531..548c6d6fb6 100644 --- a/src/util.c +++ b/src/util.c @@ -14,7 +14,7 @@ ** This file contains functions for allocating memory, comparing ** strings, and stuff like that. ** -** $Id: util.c,v 1.225 2008/05/01 02:47:04 shane Exp $ +** $Id: util.c,v 1.226 2008/05/09 03:07:34 drh Exp $ */ #include "sqliteInt.h" #include @@ -25,8 +25,19 @@ ** Return true if the floating point value is Not a Number. */ int sqlite3IsNaN(double x){ +#if 0 + /* This reportedly fails when compiled with -ffinite-math-only */ volatile double y = x; return x!=y; +#endif + /* We have to look at bit patterns to accurately determine NaN. + ** See ticket #3101 and + ** https://mail.mozilla.org/pipermail/tamarin-devel/2008-February/000325.html + */ + sqlite3_uint64 y = *(sqlite3_uint64*)&x; + assert( sizeof(x)==sizeof(y) ); + y &= (((sqlite3_uint64)0x80000000)<<32)-1; + return y > (((sqlite3_uint64)0x7ff00000)<<32); } /*