d2399a
From 22882a9d89712ff2b6ebc20a689a89452bba4dcd Mon Sep 17 00:00:00 2001
d2399a
From: Xinchen Hui <laruence@php.net>
d2399a
Date: Wed, 2 Jul 2014 17:57:42 +0800
d2399a
Subject: [PATCH] Fixed bug #67539 (ArrayIterator use-after-free due to object
d2399a
 change during sorting)
d2399a
d2399a
---
d2399a
 NEWS                        |  2 ++
d2399a
 ext/spl/spl_array.c         |  7 +++++++
d2399a
 ext/spl/tests/bug67539.phpt | 15 +++++++++++++++
d2399a
 3 files changed, 24 insertions(+)
d2399a
 create mode 100644 ext/spl/tests/bug67539.phpt
d2399a
d2399a
diff --git a/ext/spl/spl_array.c b/ext/spl/spl_array.c
d2399a
index 8392e72..0fe47b6 100644
d2399a
--- a/ext/spl/spl_array.c
d2399a
+++ b/ext/spl/spl_array.c
d2399a
@@ -1738,6 +1738,7 @@ SPL_METHOD(Array, unserialize)
d2399a
 	const unsigned char *p, *s;
d2399a
 	php_unserialize_data_t var_hash;
d2399a
 	zval *pmembers, *pflags = NULL;
d2399a
+	HashTable *aht;
d2399a
 	long flags;
d2399a
 	
d2399a
 	if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &buf, &buf_len) == FAILURE) {
d2399a
@@ -1749,6 +1750,12 @@ SPL_METHOD(Array, unserialize)
d2399a
 		return;
d2399a
 	}
d2399a
 
d2399a
+	aht = spl_array_get_hash_table(intern, 0 TSRMLS_CC);
d2399a
+	if (aht->nApplyCount > 0) {
d2399a
+		zend_error(E_WARNING, "Modification of ArrayObject during sorting is prohibited");
d2399a
+		return;
d2399a
+	}
d2399a
+
d2399a
 	/* storage */
d2399a
 	s = p = (const unsigned char*)buf;
d2399a
 	PHP_VAR_UNSERIALIZE_INIT(var_hash);
d2399a
diff --git a/ext/spl/tests/bug67539.phpt b/ext/spl/tests/bug67539.phpt
d2399a
new file mode 100644
d2399a
index 0000000..8bab2a8
d2399a
--- /dev/null
d2399a
+++ b/ext/spl/tests/bug67539.phpt
d2399a
@@ -0,0 +1,15 @@
d2399a
+--TEST--
d2399a
+Bug #67539 (ArrayIterator use-after-free due to object change during sorting)
d2399a
+--FILE--
d2399a
+
d2399a
+
d2399a
+$it = new ArrayIterator(array_fill(0,2,'X'), 1 );
d2399a
+
d2399a
+function badsort($a, $b) {
d2399a
+        $GLOBALS['it']->unserialize($GLOBALS['it']->serialize());
d2399a
+        return TRUE;
d2399a
+}
d2399a
+
d2399a
+$it->uksort('badsort');
d2399a
+--EXPECTF--
d2399a
+Warning: Modification of ArrayObject during sorting is prohibited in %sbug67539.php on line %d
d2399a
-- 
d2399a
1.9.2
d2399a