summaryrefslogtreecommitdiff
path: root/Zend/zend_compile.c
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2020-07-07 09:55:28 +0200
committerNikita Popov <nikita.ppv@gmail.com>2020-07-07 09:56:14 +0200
commit971e5c5186a2a2339b0dbad4f2a057a9deed5aa2 (patch)
tree366cc9ef7b8d26080acfc8b2af269020260740aa /Zend/zend_compile.c
parenta58d865f65acba6b876a6ed1960aaa7b28685e34 (diff)
downloadphp-git-971e5c5186a2a2339b0dbad4f2a057a9deed5aa2.tar.gz
Fixed bug #79783
Make sure we don't drop the by-reference check when passing the result of a VM builtin function.
Diffstat (limited to 'Zend/zend_compile.c')
-rw-r--r--Zend/zend_compile.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/Zend/zend_compile.c b/Zend/zend_compile.c
index 8b36a0940e..10ea65f89d 100644
--- a/Zend/zend_compile.c
+++ b/Zend/zend_compile.c
@@ -3009,7 +3009,11 @@ uint32_t zend_compile_args(zend_ast *ast, zend_function *fbc) /* {{{ */
zend_compile_var(&arg_node, arg, BP_VAR_R, 0);
if (arg_node.op_type & (IS_CONST|IS_TMP_VAR)) {
/* Function call was converted into builtin instruction */
- opcode = ZEND_SEND_VAL;
+ if (!fbc || ARG_MUST_BE_SENT_BY_REF(fbc, arg_num)) {
+ opcode = ZEND_SEND_VAL_EX;
+ } else {
+ opcode = ZEND_SEND_VAL;
+ }
} else {
if (fbc) {
if (ARG_MUST_BE_SENT_BY_REF(fbc, arg_num)) {