summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristoph M. Becker <cmbecker69@gmx.de>2020-07-31 09:12:22 +0200
committerChristoph M. Becker <cmbecker69@gmx.de>2020-07-31 10:54:41 +0200
commit1e0bc6e30f9fb327cd06383c8290a8afab1e484d (patch)
tree0031ae5b38adff0949647b8b449350804a8bf1e8
parentd95c53834cec1570b8f3e836cd514d6ae5901e68 (diff)
downloadphp-git-1e0bc6e30f9fb327cd06383c8290a8afab1e484d.tar.gz
Fix #79919: Stack use-after-scope in define()
Instead of the temporary `rv`, we use the `val_free` which is there for this purpose.
-rw-r--r--NEWS1
-rw-r--r--Zend/tests/bug79919.phpt14
-rw-r--r--Zend/zend_builtin_functions.c4
3 files changed, 16 insertions, 3 deletions
diff --git a/NEWS b/NEWS
index 1a5d787307..ebdb9601ee 100644
--- a/NEWS
+++ b/NEWS
@@ -8,6 +8,7 @@ PHP NEWS
. Fixed bug #79806 (realpath() erroneously resolves link to link). (cmb)
. Fixed bug #79895 (PHP_CHECK_GCC_ARG does not allow flags with equal sign).
(Santiago M. Mola)
+ . Fixed bug #79919 (Stack use-after-scope in define()). (cmb)
- LDAP:
. Fixed memory leaks. (ptomulik)
diff --git a/Zend/tests/bug79919.phpt b/Zend/tests/bug79919.phpt
new file mode 100644
index 0000000000..c135722675
--- /dev/null
+++ b/Zend/tests/bug79919.phpt
@@ -0,0 +1,14 @@
+--TEST--
+Bug #79919 (Stack use-after-scope in define())
+--SKIPIF--
+<?php
+if (!extension_loaded('simplexml')) die('skip simplexml extension not available');
+?>
+--FILE--
+<?php
+$b = error_log(0);
+$b = simplexml_load_string('<xml/>', null, $b);
+define(0, $b);
+?>
+--EXPECT--
+0
diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c
index bc3649a622..468a7c3446 100644
--- a/Zend/zend_builtin_functions.c
+++ b/Zend/zend_builtin_functions.c
@@ -882,9 +882,7 @@ repeat:
case IS_OBJECT:
if (Z_TYPE(val_free) == IS_UNDEF) {
if (Z_OBJ_HT_P(val)->get) {
- zval rv;
- val = Z_OBJ_HT_P(val)->get(val, &rv);
- ZVAL_COPY_VALUE(&val_free, val);
+ val = Z_OBJ_HT_P(val)->get(val, &val_free);
goto repeat;
} else if (Z_OBJ_HT_P(val)->cast_object) {
if (Z_OBJ_HT_P(val)->cast_object(val, &val_free, IS_STRING) == SUCCESS) {