summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2020-09-03 09:51:35 +0200
committerNikita Popov <nikita.ppv@gmail.com>2020-09-03 09:51:35 +0200
commit0fc65ed13373b1276062cda5b1e4993243203e5e (patch)
treec8083b601e09f79938699601b2cca12095b176ad
parent81811dbbfba4f52c68fd9a08c3a0979de57f530f (diff)
parent573ad182d21df2457a0a2f6fd3c075e1f0bfca44 (diff)
downloadphp-git-0fc65ed13373b1276062cda5b1e4993243203e5e.tar.gz
Merge branch 'PHP-7.3' into PHP-7.4
* PHP-7.3: Handle memory limit error during string reallocation correctly
-rw-r--r--Zend/zend_string.h20
1 files changed, 12 insertions, 8 deletions
diff --git a/Zend/zend_string.h b/Zend/zend_string.h
index b4a0ddef95..96169d9a27 100644
--- a/Zend/zend_string.h
+++ b/Zend/zend_string.h
@@ -186,12 +186,13 @@ static zend_always_inline zend_string *zend_string_realloc(zend_string *s, size_
ZSTR_LEN(ret) = len;
zend_string_forget_hash_val(ret);
return ret;
- } else {
- GC_DELREF(s);
}
}
ret = zend_string_alloc(len, persistent);
memcpy(ZSTR_VAL(ret), ZSTR_VAL(s), MIN(len, ZSTR_LEN(s)) + 1);
+ if (!ZSTR_IS_INTERNED(s)) {
+ GC_DELREF(s);
+ }
return ret;
}
@@ -206,12 +207,13 @@ static zend_always_inline zend_string *zend_string_extend(zend_string *s, size_t
ZSTR_LEN(ret) = len;
zend_string_forget_hash_val(ret);
return ret;
- } else {
- GC_DELREF(s);
}
}
ret = zend_string_alloc(len, persistent);
memcpy(ZSTR_VAL(ret), ZSTR_VAL(s), ZSTR_LEN(s) + 1);
+ if (!ZSTR_IS_INTERNED(s)) {
+ GC_DELREF(s);
+ }
return ret;
}
@@ -226,12 +228,13 @@ static zend_always_inline zend_string *zend_string_truncate(zend_string *s, size
ZSTR_LEN(ret) = len;
zend_string_forget_hash_val(ret);
return ret;
- } else {
- GC_DELREF(s);
}
}
ret = zend_string_alloc(len, persistent);
memcpy(ZSTR_VAL(ret), ZSTR_VAL(s), len + 1);
+ if (!ZSTR_IS_INTERNED(s)) {
+ GC_DELREF(s);
+ }
return ret;
}
@@ -245,12 +248,13 @@ static zend_always_inline zend_string *zend_string_safe_realloc(zend_string *s,
ZSTR_LEN(ret) = (n * m) + l;
zend_string_forget_hash_val(ret);
return ret;
- } else {
- GC_DELREF(s);
}
}
ret = zend_string_safe_alloc(n, m, l, persistent);
memcpy(ZSTR_VAL(ret), ZSTR_VAL(s), MIN((n * m) + l, ZSTR_LEN(s)) + 1);
+ if (!ZSTR_IS_INTERNED(s)) {
+ GC_DELREF(s);
+ }
return ret;
}