]> granicus.if.org Git - php/commitdiff
Fixed bug #74954 (null deref and segfault in zend_generator_resume())
authorBob Weinand <bobwei9@hotmail.com>
Sat, 22 Jul 2017 09:14:00 +0000 (11:14 +0200)
committerBob Weinand <bobwei9@hotmail.com>
Sat, 22 Jul 2017 09:14:00 +0000 (11:14 +0200)
NEWS
Zend/tests/generators/bug74954.phpt [new file with mode: 0644]
Zend/zend_generators.c

diff --git a/NEWS b/NEWS
index f174c5cfa283cae3dc951243d4603e99cd04d9ca..fed2edb098a40feddda73283acf24a303fa431cf 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -4,6 +4,7 @@ PHP                                                                        NEWS
 
 - Core:
   . Fixed bug #74947 (Segfault in scanner on INF number). (Laruence)
+  . Fixed bug #74954 (null deref and segfault in zend_generator_resume()). (Bob)
 
 - SimpleXML:
   . Fixed bug #74950 (nullpointer deref in simplexml_element_getDocNamespaces).
diff --git a/Zend/tests/generators/bug74954.phpt b/Zend/tests/generators/bug74954.phpt
new file mode 100644 (file)
index 0000000..58a61af
--- /dev/null
@@ -0,0 +1,45 @@
+--TEST--
+Bug #74954 (crash after update of generator yielding from finished generator)
+--FILE--
+<?php
+
+function from() {
+        yield 1;
+        throw new Exception();
+}
+
+function gen($gen) {
+        try {
+                var_dump(yield from $gen);
+        } catch (Exception $e) { print "Caught exception!\n$e\n"; }
+}
+
+$gen = from();
+$gens[] = gen($gen);
+$gens[] = gen($gen);
+
+foreach ($gens as $g) {
+        $g->current();
+}
+
+do {
+        foreach ($gens as $i => $g) {
+                $g->next();
+        }
+} while($gens[0]->valid());
+
+?>
+--EXPECTF--
+Caught exception!
+Exception in %s:%d
+Stack trace:
+#0 %s(%d): from()
+#1 [internal function]: gen(Object(Generator))
+#2 %s(%d): Generator->next()
+#3 {main}
+Caught exception!
+ClosedGeneratorException: Generator yielded from aborted, no return value available in %s:%d
+Stack trace:
+#0 [internal function]: gen(Object(Generator))
+#1 %s(%d): Generator->next()
+#2 {main}
index fd09831080d236f1c76c1a3389c4d21259f4c0b1..37faca1f0001bc7d31bb595f2f67fdeaa3dba0ac 100644 (file)
@@ -644,15 +644,13 @@ failure:
 
 ZEND_API void zend_generator_resume(zend_generator *orig_generator) /* {{{ */
 {
-       zend_generator *generator;
+       zend_generator *generator = zend_generator_get_current(orig_generator);
 
        /* The generator is already closed, thus can't resume */
-       if (UNEXPECTED(!orig_generator->execute_data)) {
+       if (UNEXPECTED(!generator->execute_data)) {
                return;
        }
 
-       generator = zend_generator_get_current(orig_generator);
-
 try_again:
        if (generator->flags & ZEND_GENERATOR_CURRENTLY_RUNNING) {
                zend_throw_error(NULL, "Cannot resume an already running generator");