diff --git a/src/ArduinoJson/Numbers/FloatTraits.hpp b/src/ArduinoJson/Numbers/FloatTraits.hpp
index 1fff5708..030fd54d 100644
--- a/src/ArduinoJson/Numbers/FloatTraits.hpp
+++ b/src/ArduinoJson/Numbers/FloatTraits.hpp
@@ -50,68 +50,65 @@ struct FloatTraits {
static T positiveBinaryPowerOfTen(int index) {
ARDUINOJSON_DEFINE_PROGMEM_ARRAY( //
- uint32_t, factors,
+ uint64_t, factors,
{
- 0x40240000, 0x00000000, // 1e1
- 0x40590000, 0x00000000, // 1e2
- 0x40C38800, 0x00000000, // 1e4
- 0x4197D784, 0x00000000, // 1e8
- 0x4341C379, 0x37E08000, // 1e16
- 0x4693B8B5, 0xB5056E17, // 1e32
- 0x4D384F03, 0xE93FF9F5, // 1e64
- 0x5A827748, 0xF9301D32, // 1e128
- 0x75154FDD, 0x7F73BF3C // 1e256
+ 0x4024000000000000, // 1e1
+ 0x4059000000000000, // 1e2
+ 0x40C3880000000000, // 1e4
+ 0x4197D78400000000, // 1e8
+ 0x4341C37937E08000, // 1e16
+ 0x4693B8B5B5056E17, // 1e32
+ 0x4D384F03E93FF9F5, // 1e64
+ 0x5A827748F9301D32, // 1e128
+ 0x75154FDD7F73BF3C, // 1e256
});
- return forge(pgm_read(factors + 2 * index),
- pgm_read(factors + 2 * index + 1));
+ return forge(pgm_read(factors + index));
}
static T negativeBinaryPowerOfTen(int index) {
ARDUINOJSON_DEFINE_PROGMEM_ARRAY( //
- uint32_t, factors,
+ uint64_t, factors,
{
- 0x3FB99999, 0x9999999A, // 1e-1
- 0x3F847AE1, 0x47AE147B, // 1e-2
- 0x3F1A36E2, 0xEB1C432D, // 1e-4
- 0x3E45798E, 0xE2308C3A, // 1e-8
- 0x3C9CD2B2, 0x97D889BC, // 1e-16
- 0x3949F623, 0xD5A8A733, // 1e-32
- 0x32A50FFD, 0x44F4A73D, // 1e-64
- 0x255BBA08, 0xCF8C979D, // 1e-128
- 0x0AC80628, 0x64AC6F43 // 1e-256
+ 0x3FB999999999999A, // 1e-1
+ 0x3F847AE147AE147B, // 1e-2
+ 0x3F1A36E2EB1C432D, // 1e-4
+ 0x3E45798EE2308C3A, // 1e-8
+ 0x3C9CD2B297D889BC, // 1e-16
+ 0x3949F623D5A8A733, // 1e-32
+ 0x32A50FFD44F4A73D, // 1e-64
+ 0x255BBA08CF8C979D, // 1e-128
+ 0x0AC8062864AC6F43 // 1e-256
});
- return forge(pgm_read(factors + 2 * index),
- pgm_read(factors + 2 * index + 1));
+ return forge(pgm_read(factors + index));
}
static T negativeBinaryPowerOfTenPlusOne(int index) {
ARDUINOJSON_DEFINE_PROGMEM_ARRAY( //
- uint32_t, factors,
+ uint64_t, factors,
{
- 0x3FF00000, 0x00000000, // 1e0
- 0x3FB99999, 0x9999999A, // 1e-1
- 0x3F50624D, 0xD2F1A9FC, // 1e-3
- 0x3E7AD7F2, 0x9ABCAF48, // 1e-7
- 0x3CD203AF, 0x9EE75616, // 1e-15
- 0x398039D6, 0x65896880, // 1e-31
- 0x32DA53FC, 0x9631D10D, // 1e-63
- 0x25915445, 0x81B7DEC2, // 1e-127
- 0x0AFE07B2, 0x7DD78B14 // 1e-255
+ 0x3FF0000000000000, // 1e0
+ 0x3FB999999999999A, // 1e-1
+ 0x3F50624DD2F1A9FC, // 1e-3
+ 0x3E7AD7F29ABCAF48, // 1e-7
+ 0x3CD203AF9EE75616, // 1e-15
+ 0x398039D665896880, // 1e-31
+ 0x32DA53FC9631D10D, // 1e-63
+ 0x2591544581B7DEC2, // 1e-127
+ 0x0AFE07B27DD78B14 // 1e-255
});
- return forge(pgm_read(factors + 2 * index),
- pgm_read(factors + 2 * index + 1));
+ return forge(pgm_read(factors + index));
}
static T nan() {
- return forge(0x7ff80000, 0x00000000);
+ return forge(0x7ff8000000000000);
}
static T inf() {
- return forge(0x7ff00000, 0x00000000);
+ return forge(0x7ff0000000000000);
}
static T highest() {
- return forge(0x7FEFFFFF, 0xFFFFFFFF);
+ return forge(0x7FEFFFFFFFFFFFFF);
}
template // int64_t
@@ -119,7 +116,7 @@ struct FloatTraits {
typename enable_if::value && is_signed::value &&
sizeof(TOut) == 8,
signed>::type* = 0) {
- return forge(0x43DFFFFF, 0xFFFFFFFF); // 9.2233720368547748e+18
+ return forge(0x43DFFFFFFFFFFFFF); // 9.2233720368547748e+18
}
template // uint64_t
@@ -127,18 +124,18 @@ struct FloatTraits {
typename enable_if::value && is_unsigned::value &&
sizeof(TOut) == 8,
unsigned>::type* = 0) {
- return forge(0x43EFFFFF, 0xFFFFFFFF); // 1.8446744073709549568e+19
+ return forge(0x43EFFFFFFFFFFFFF); // 1.8446744073709549568e+19
}
static T lowest() {
- return forge(0xFFEFFFFF, 0xFFFFFFFF);
+ return forge(0xFFEFFFFFFFFFFFFF);
}
// constructs a double floating point values from its binary representation
// we use this function to workaround platforms with single precision literals
// (for example, when -fsingle-precision-constant is passed to GCC)
- static T forge(uint32_t msb, uint32_t lsb) {
- return alias_cast((uint64_t(msb) << 32) | lsb);
+ static T forge(uint64_t bits) {
+ return alias_cast(bits);
}
};
diff --git a/src/ArduinoJson/Polyfills/pgmspace_generic.hpp b/src/ArduinoJson/Polyfills/pgmspace_generic.hpp
index 0903ba50..f5b50b8d 100644
--- a/src/ArduinoJson/Polyfills/pgmspace_generic.hpp
+++ b/src/ArduinoJson/Polyfills/pgmspace_generic.hpp
@@ -28,6 +28,14 @@ inline const T* pgm_read(const T* const* p) {
inline uint32_t pgm_read(const uint32_t* p) {
return pgm_read_dword(p);
}
+
+template
+inline T pgm_read(const T* p) {
+ T result;
+ memcpy_P(&result, p, sizeof(T));
+ return result;
+}
+
#else
# ifndef ARDUINOJSON_DEFINE_PROGMEM_ARRAY