From f65ae82c55b986fbc1e140de998b4a9c44911cac Mon Sep 17 00:00:00 2001 From: andrewnester Date: Tue, 24 Jan 2017 16:38:30 +0300 Subject: [PATCH] Fixed #73973 - debug_zval_dump() assertion error for resource consts with --enable-debug --- NEWS | 1 + Zend/zend_builtin_functions.c | 8 -------- Zend/zend_execute_API.c | 8 ++++---- ext/standard/tests/general_functions/bug73973.phpt | 9 +++++++++ 4 files changed, 14 insertions(+), 12 deletions(-) create mode 100644 ext/standard/tests/general_functions/bug73973.phpt diff --git a/NEWS b/NEWS index 686efb6643..b0566a9ccc 100644 --- a/NEWS +++ b/NEWS @@ -8,6 +8,7 @@ PHP NEWS . Fixed bug #73876 (Crash when exporting **= in expansion of assign op). (Sara) . Fixed bug #73969 (segfault in debug_print_backtrace). (andrewnester) + . Fixed bug #73973 (assertion error in debug_zval_dump). (andrewnester) - DOM: . Fixed bug #54382 (getAttributeNodeNS doesn't get xmlns* attributes). diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c index 547d3f0b8f..aa705d3235 100644 --- a/Zend/zend_builtin_functions.c +++ b/Zend/zend_builtin_functions.c @@ -808,9 +808,6 @@ static void copy_constant_array(zval *dst, zval *src) /* {{{ */ } } else if (Z_REFCOUNTED_P(val)) { Z_ADDREF_P(val); - if (UNEXPECTED(Z_TYPE_INFO_P(val) == IS_RESOURCE_EX)) { - Z_TYPE_INFO_P(new_val) &= ~(IS_TYPE_REFCOUNTED << Z_TYPE_FLAGS_SHIFT); - } } } ZEND_HASH_FOREACH_END(); } @@ -853,12 +850,7 @@ repeat: case IS_FALSE: case IS_TRUE: case IS_NULL: - break; case IS_RESOURCE: - ZVAL_COPY(&val_free, val); - /* TODO: better solution than this tricky disable dtor on resource? */ - Z_TYPE_INFO(val_free) &= ~(IS_TYPE_REFCOUNTED << Z_TYPE_FLAGS_SHIFT); - val = &val_free; break; case IS_ARRAY: if (!Z_IMMUTABLE_P(val)) { diff --git a/Zend/zend_execute_API.c b/Zend/zend_execute_API.c index 51baac2250..28a75b7190 100644 --- a/Zend/zend_execute_API.c +++ b/Zend/zend_execute_API.c @@ -343,6 +343,10 @@ void shutdown_executor(void) /* {{{ */ zend_llist_destroy(&CG(open_files)); } zend_end_try(); + zend_try { + clean_non_persistent_constants(); + } zend_end_try(); + zend_try { zend_close_rsrc_list(&EG(regular_list)); } zend_end_try(); @@ -374,10 +378,6 @@ void shutdown_executor(void) /* {{{ */ } } zend_end_try(); - zend_try { - clean_non_persistent_constants(); - } zend_end_try(); - zend_try { #if 0&&ZEND_DEBUG signal(SIGSEGV, original_sigsegv_handler); diff --git a/ext/standard/tests/general_functions/bug73973.phpt b/ext/standard/tests/general_functions/bug73973.phpt new file mode 100644 index 0000000000..8bb4daaab0 --- /dev/null +++ b/ext/standard/tests/general_functions/bug73973.phpt @@ -0,0 +1,9 @@ +--TEST-- +Bug #73973 debug_zval_dump() assertion error for resource consts with --enable-debug +--FILE-- + +--EXPECTF-- +resource(5) of type (stream) refcount(%d) -- 2.40.0