summaryrefslogtreecommitdiff
path: root/Zend/zend_inheritance.c
diff options
context:
space:
mode:
authorXinchen Hui <laruence@php.net>2015-07-10 15:27:06 +0800
committerXinchen Hui <laruence@php.net>2015-07-10 15:27:06 +0800
commita3f05d640d73d61c1978446adb1217f40356d037 (patch)
treeeaa4480ed2ef1c223a434fcd41b3404f4589210c /Zend/zend_inheritance.c
parentef1b588f6a39bcc2c0d5fad9f2094bb011aeaf0b (diff)
downloadphp-git-a3f05d640d73d61c1978446adb1217f40356d037.tar.gz
Fixed Issue #1400 (double free static property)
Diffstat (limited to 'Zend/zend_inheritance.c')
-rw-r--r--Zend/zend_inheritance.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/Zend/zend_inheritance.c b/Zend/zend_inheritance.c
index 64e7407f12..9b96a4a479 100644
--- a/Zend/zend_inheritance.c
+++ b/Zend/zend_inheritance.c
@@ -821,7 +821,13 @@ ZEND_API void zend_do_inheritance(zend_class_entry *ce, zend_class_entry *parent
do {
dst--;
src--;
- ZVAL_MAKE_REF(src);
+ if (parent_ce->type == ZEND_INTERNAL_CLASS) {
+ if (!Z_ISREF_P(src)) {
+ ZVAL_NEW_PERSISTENT_REF(src, src);
+ }
+ } else {
+ ZVAL_MAKE_REF(src);
+ }
ZVAL_COPY_VALUE(dst, src);
Z_ADDREF_P(dst);
if (Z_CONSTANT_P(Z_REFVAL_P(dst))) {