summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAntony Dovgal <tony2001@php.net>2006-02-14 22:15:15 +0000
committerAntony Dovgal <tony2001@php.net>2006-02-14 22:15:15 +0000
commitccef27192e59e588061b524681198ff8afe9bfbc (patch)
treef44e2344315f8e23635ce124dc38d61efa7aafb9
parent66c19b66e4b68fec2fdcd87b2691662877695956 (diff)
downloadphp-git-ccef27192e59e588061b524681198ff8afe9bfbc.tar.gz
MF51:
fix leak in zend_strtod() on big doubles
-rw-r--r--Zend/zend_strtod.c18
1 files changed, 17 insertions, 1 deletions
diff --git a/Zend/zend_strtod.c b/Zend/zend_strtod.c
index 87d755006a..3ad2c5f155 100644
--- a/Zend/zend_strtod.c
+++ b/Zend/zend_strtod.c
@@ -1250,7 +1250,7 @@ zend_strtod
_double rv, rv0;
Long L;
ULong y, z;
- Bigint *bb, *bb1, *bd, *bd0, *bs, *delta;
+ Bigint *bb, *bb1, *bd, *bd0, *bs, *delta, *tmp;
double result;
CONST char decimal_point = '.';
@@ -1776,5 +1776,21 @@ zend_strtod
if (se)
*se = (char *)s;
result = sign ? -value(rv) : value(rv);
+
+ for (i = 0; i <= Kmax; i++) {
+ Bigint **listp = &freelist[i];
+ while ((tmp = *listp) != NULL) {
+ *listp = tmp->next;
+ free(tmp);
+ }
+ freelist[i] = NULL;
+ }
+
+ while (p5s) {
+ tmp = p5s;
+ p5s = p5s->next;
+ free(tmp);
+ }
+
return result;
}