summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--contrib/gdtoa/strtorQ.c6
-rw-r--r--contrib/gdtoa/strtorx.c9
2 files changed, 14 insertions, 1 deletions
diff --git a/contrib/gdtoa/strtorQ.c b/contrib/gdtoa/strtorQ.c
index b7f9bba..bd183bc 100644
--- a/contrib/gdtoa/strtorQ.c
+++ b/contrib/gdtoa/strtorQ.c
@@ -65,6 +65,12 @@ ULtoQ(ULong *L, ULong *bits, Long exp, int k)
break;
case STRTOG_Normal:
+ L[_3] = bits[0];
+ L[_2] = bits[1];
+ L[_1] = bits[2];
+ L[_0] = (bits[3] & ~0x10000) | ((exp + 0x3fff + 112) << 16);
+ break;
+
case STRTOG_NaNbits:
L[_3] = bits[0];
L[_2] = bits[1];
diff --git a/contrib/gdtoa/strtorx.c b/contrib/gdtoa/strtorx.c
index 52d7eff..e9fd45f 100644
--- a/contrib/gdtoa/strtorx.c
+++ b/contrib/gdtoa/strtorx.c
@@ -71,12 +71,19 @@ ULtox(UShort *L, ULong *bits, Long exp, int k)
goto normal_bits;
case STRTOG_Normal:
- case STRTOG_NaNbits:
L[_0] = exp + 0x3fff + 63;
normal_bits:
L[_4] = (UShort)bits[0];
L[_3] = (UShort)(bits[0] >> 16);
L[_2] = (UShort)bits[1];
+ L[_1] = (UShort)(bits[1] >> 16);
+ break;
+
+ case STRTOG_NaNbits:
+ L[_0] = exp + 0x3fff + 63;
+ L[_4] = (UShort)bits[0];
+ L[_3] = (UShort)(bits[0] >> 16);
+ L[_2] = (UShort)bits[1];
L[_1] = (UShort)((bits[1] >> 16) | (3 << 14));
break;
OpenPOWER on IntegriCloud