summaryrefslogtreecommitdiff
path: root/Zend
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@php.net>2008-03-04 11:43:51 +0000
committerDmitry Stogov <dmitry@php.net>2008-03-04 11:43:51 +0000
commit430e54d4579b6f815671fc2648ccc7fe41d89d9a (patch)
tree1be4b171608a49c59d097ccbae8f6c174f7b28a1 /Zend
parent14ec6f623bd6722733bb7cb375e34b14a57d9109 (diff)
downloadphp-git-430e54d4579b6f815671fc2648ccc7fe41d89d9a.tar.gz
Fixed shared memory corruption of opcode caches
Diffstat (limited to 'Zend')
-rw-r--r--Zend/zend_execute_API.c23
-rw-r--r--Zend/zend_vm_def.h3
-rw-r--r--Zend/zend_vm_execute.h3
3 files changed, 23 insertions, 6 deletions
diff --git a/Zend/zend_execute_API.c b/Zend/zend_execute_API.c
index d7373d86cd..2e31d5e1f5 100644
--- a/Zend/zend_execute_API.c
+++ b/Zend/zend_execute_API.c
@@ -466,6 +466,19 @@ ZEND_API int zend_is_true(zval *op) /* {{{ */
#define Z_REAL_TYPE_P(p) (Z_TYPE_P(p) & ~IS_VISITED_CONSTANT)
#define MARK_CONSTANT_VISITED(p) Z_TYPE_P(p) |= IS_VISITED_CONSTANT
+static void zval_deep_copy(zval **p)
+{
+ zval *value;
+
+ ALLOC_ZVAL(value);
+ *value = **p;
+ Z_TYPE_P(value) &= ~IS_CONSTANT_INDEX;
+ zval_copy_ctor(value);
+ Z_TYPE_P(value) = Z_TYPE_PP(p);
+ INIT_PZVAL(value);
+ *p = value;
+}
+
ZEND_API int zval_update_constant_ex(zval **pp, void *arg, zend_class_entry *scope TSRMLS_DC) /* {{{ */
{
zval *p = *pp;
@@ -531,6 +544,16 @@ ZEND_API int zval_update_constant_ex(zval **pp, void *arg, zend_class_entry *sco
p = *pp;
Z_TYPE_P(p) = IS_ARRAY;
+ if (!inline_change) {
+ zval *tmp;
+ HashTable *tmp_ht = NULL;
+
+ ALLOC_HASHTABLE(tmp_ht);
+ zend_hash_init(tmp_ht, zend_hash_num_elements(Z_ARRVAL_P(p)), NULL, ZVAL_PTR_DTOR, 0);
+ zend_hash_copy(tmp_ht, Z_ARRVAL_P(p), (copy_ctor_func_t) zval_deep_copy, (void *) &tmp, sizeof(zval *));
+ Z_ARRVAL_P(p) = tmp_ht;
+ }
+
/* First go over the array and see if there are any constant indices */
zend_hash_internal_pointer_reset(Z_ARRVAL_P(p));
while (zend_hash_get_current_data(Z_ARRVAL_P(p), (void **) &element) == SUCCESS) {
diff --git a/Zend/zend_vm_def.h b/Zend/zend_vm_def.h
index 4a4ad8867a..9f03d7e35d 100644
--- a/Zend/zend_vm_def.h
+++ b/Zend/zend_vm_def.h
@@ -2598,9 +2598,6 @@ ZEND_VM_HANDLER(64, ZEND_RECV_INIT, ANY, CONST)
ALLOC_ZVAL(default_value);
*default_value = opline->op2.u.constant;
- if (Z_TYPE(opline->op2.u.constant)==IS_CONSTANT_ARRAY) {
- zval_copy_ctor(default_value);
- }
Z_SET_REFCOUNT_P(default_value, 1);
zval_update_constant(&default_value, 0 TSRMLS_CC);
Z_SET_REFCOUNT_P(default_value, 0);
diff --git a/Zend/zend_vm_execute.h b/Zend/zend_vm_execute.h
index 33ee07673d..0acfdab2b6 100644
--- a/Zend/zend_vm_execute.h
+++ b/Zend/zend_vm_execute.h
@@ -723,9 +723,6 @@ static int ZEND_RECV_INIT_SPEC_CONST_HANDLER(ZEND_OPCODE_HANDLER_ARGS)
ALLOC_ZVAL(default_value);
*default_value = opline->op2.u.constant;
- if (Z_TYPE(opline->op2.u.constant)==IS_CONSTANT_ARRAY) {
- zval_copy_ctor(default_value);
- }
Z_SET_REFCOUNT_P(default_value, 1);
zval_update_constant(&default_value, 0 TSRMLS_CC);
Z_SET_REFCOUNT_P(default_value, 0);