diff options
| -rw-r--r-- | NEWS | 2 | ||||
| -rw-r--r-- | Zend/tests/bug70547.phpt | 48 | ||||
| -rw-r--r-- | Zend/zend_builtin_functions.c | 16 |
3 files changed, 62 insertions, 4 deletions
@@ -3,6 +3,8 @@ PHP NEWS 01 Oct 2015, PHP 7.0.0 RC 4 - Core: + . Fixed bug #70547 (unsetting function variables corrupts backtrace). + (Laruence) . Fixed bug #70528 (assert() with instanceof adds apostrophes around class name). (Laruence) . Fixed bug #70481 (Memory leak in auto_global_copy_ctor() in ZTS build). diff --git a/Zend/tests/bug70547.phpt b/Zend/tests/bug70547.phpt new file mode 100644 index 0000000000..195495dcdc --- /dev/null +++ b/Zend/tests/bug70547.phpt @@ -0,0 +1,48 @@ +--TEST-- +Bug #70547 (unsetting function variables corrupts backtrace) +--FILE-- +<?php +function brokenTrace($arg1, $arg2, $arg3){ + backtraceWrapper(); + unset($arg3); + backtraceWrapper(); + unset($arg1); + backtraceWrapper(); + unset($arg2); + backtraceWrapper(); +} +brokenTrace("1st", "2nd", "3th", "4th"); +function backtraceWrapper(){ + $bt = debug_backtrace(); + var_dump($bt[1]['args']); +} +?> +--EXPECT-- +array(4) { + [0]=> + string(3) "1st" + [1]=> + string(3) "2nd" + [2]=> + string(3) "3th" + [3]=> + string(3) "4th" +} +array(3) { + [0]=> + string(3) "1st" + [1]=> + string(3) "2nd" + [2]=> + string(3) "4th" +} +array(2) { + [0]=> + string(3) "2nd" + [1]=> + string(3) "4th" +} +array(1) { + [0]=> + string(3) "4th" +} diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c index e3f087b356..b0e4f6ab02 100644 --- a/Zend/zend_builtin_functions.c +++ b/Zend/zend_builtin_functions.c @@ -2233,8 +2233,12 @@ static void debug_backtrace_get_args(zend_execute_data *call, zval *arg_array) / if (ZEND_CALL_NUM_ARGS(call) > first_extra_arg) { while (i < first_extra_arg) { - if (Z_OPT_REFCOUNTED_P(p)) Z_ADDREF_P(p); - ZEND_HASH_FILL_ADD(p); + if (Z_TYPE_INFO_P(p) != IS_UNDEF) { + if (Z_OPT_REFCOUNTED_P(p)) { + Z_ADDREF_P(p); + } + ZEND_HASH_FILL_ADD(p); + } p++; i++; } @@ -2243,8 +2247,12 @@ static void debug_backtrace_get_args(zend_execute_data *call, zval *arg_array) / } while (i < num_args) { - if (Z_OPT_REFCOUNTED_P(p)) Z_ADDREF_P(p); - ZEND_HASH_FILL_ADD(p); + if (Z_TYPE_INFO_P(p) != IS_UNDEF) { + if (Z_OPT_REFCOUNTED_P(p)) { + Z_ADDREF_P(p); + } + ZEND_HASH_FILL_ADD(p); + } p++; i++; } |
