diff options
| author | Dmitry Stogov <dmitry@zend.com> | 2016-07-14 13:14:15 +0300 | 
|---|---|---|
| committer | Dmitry Stogov <dmitry@zend.com> | 2016-07-14 13:14:15 +0300 | 
| commit | 9a76189caf5b660224f0dffdd7fcb4783c8d7fdc (patch) | |
| tree | 95efbb599ea6a23fa1d6ea7f8a1178473627d78d | |
| parent | 61580460c81d5f8e4cf170ec6a1efd9c2d15a4db (diff) | |
| download | php-git-9a76189caf5b660224f0dffdd7fcb4783c8d7fdc.tar.gz | |
Fixed memory leak
| -rw-r--r-- | Zend/zend_vm_def.h | 4 | ||||
| -rw-r--r-- | Zend/zend_vm_execute.h | 12 | 
2 files changed, 16 insertions, 0 deletions
| diff --git a/Zend/zend_vm_def.h b/Zend/zend_vm_def.h index ce3fbeb98c..a40b2cb39c 100644 --- a/Zend/zend_vm_def.h +++ b/Zend/zend_vm_def.h @@ -5383,6 +5383,10 @@ ZEND_VM_HANDLER(73, ZEND_INCLUDE_OR_EVAL, CONST|TMPVAR|CV, ANY, EVAL)  	new_op_array = zend_include_or_eval(inc_filename, opline->extended_value);  	FREE_OP1();  	if (UNEXPECTED(EG(exception) != NULL)) { +		if (new_op_array != ZEND_FAKE_OP_ARRAY && new_op_array != NULL) { +			destroy_op_array(new_op_array); +			efree_size(new_op_array, sizeof(zend_op_array)); +		}  		HANDLE_EXCEPTION();  	} else if (new_op_array == ZEND_FAKE_OP_ARRAY) {  		if (RETURN_VALUE_USED(opline)) { diff --git a/Zend/zend_vm_execute.h b/Zend/zend_vm_execute.h index ef73b195a0..5a53938ef3 100644 --- a/Zend/zend_vm_execute.h +++ b/Zend/zend_vm_execute.h @@ -3387,6 +3387,10 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_INCLUDE_OR_EVAL_SPEC_CONST_HAN  	new_op_array = zend_include_or_eval(inc_filename, opline->extended_value);  	if (UNEXPECTED(EG(exception) != NULL)) { +		if (new_op_array != ZEND_FAKE_OP_ARRAY && new_op_array != NULL) { +			destroy_op_array(new_op_array); +			efree_size(new_op_array, sizeof(zend_op_array)); +		}  		HANDLE_EXCEPTION();  	} else if (new_op_array == ZEND_FAKE_OP_ARRAY) {  		if (RETURN_VALUE_USED(opline)) { @@ -35120,6 +35124,10 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_INCLUDE_OR_EVAL_SPEC_CV_HANDLE  	new_op_array = zend_include_or_eval(inc_filename, opline->extended_value);  	if (UNEXPECTED(EG(exception) != NULL)) { +		if (new_op_array != ZEND_FAKE_OP_ARRAY && new_op_array != NULL) { +			destroy_op_array(new_op_array); +			efree_size(new_op_array, sizeof(zend_op_array)); +		}  		HANDLE_EXCEPTION();  	} else if (new_op_array == ZEND_FAKE_OP_ARRAY) {  		if (RETURN_VALUE_USED(opline)) { @@ -51046,6 +51054,10 @@ static ZEND_OPCODE_HANDLER_RET ZEND_FASTCALL ZEND_INCLUDE_OR_EVAL_SPEC_TMPVAR_HA  	new_op_array = zend_include_or_eval(inc_filename, opline->extended_value);  	zval_ptr_dtor_nogc(free_op1);  	if (UNEXPECTED(EG(exception) != NULL)) { +		if (new_op_array != ZEND_FAKE_OP_ARRAY && new_op_array != NULL) { +			destroy_op_array(new_op_array); +			efree_size(new_op_array, sizeof(zend_op_array)); +		}  		HANDLE_EXCEPTION();  	} else if (new_op_array == ZEND_FAKE_OP_ARRAY) {  		if (RETURN_VALUE_USED(opline)) { | 
