]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Fix array overflow in floating point parser
authorAndreas Schwab <schwab@redhat.com>
Wed, 1 Sep 2010 19:38:44 +0000 (12:38 -0700)
committerPetr Baudis <pasky@suse.cz>
Tue, 9 Nov 2010 01:12:46 +0000 (02:12 +0100)
(cherry picked from commit a726d7960e8a4ac784131f591114a0ef14246d8b)

ChangeLog
stdlib/strtod_l.c

index c8bdd6dba20c3212e085bf4e99377d13a6552edb..5b04f1b5ad119927060ac9e8014829395f35259e 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2010-08-31  Andreas Schwab  <schwab@redhat.com>
+
+       [BZ #7066]
+       * stdlib/strtod_l.c (____STRTOF_INTERNAL): Fix array overflow when
+       shifting retval into place.
+
 2010-09-14  Ulrich Drepper  <drepper@redhat.com>
 
        * resolv/res_init.c (__res_vinit): Count the default server we added.
index 9ddfa3fa6635af51c59f4cd55f248e910a602a05..099fcf751e40439121a213a34a6696d9a8687788 100644 (file)
@@ -1491,7 +1491,9 @@ ____STRTOF_INTERNAL (nptr, endptr, group, loc)
                          register int i;
                          (void) __mpn_lshift (&retval[used
                                                       / BITS_PER_MP_LIMB],
-                                              retval, RETURN_LIMB_SIZE,
+                                              retval,
+                                              (RETURN_LIMB_SIZE
+                                               - used / BITS_PER_MP_LIMB),
                                               used % BITS_PER_MP_LIMB);
                          for (i = used / BITS_PER_MP_LIMB - 1; i >= 0; --i)
                            retval[i] = 0;