summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDmitry Stogov <dmitry@zend.com>2015-06-29 17:45:56 +0300
committerDmitry Stogov <dmitry@zend.com>2015-06-29 18:01:01 +0300
commitdc588997e202b5a645052bfb21098cc571693569 (patch)
tree66aceac384c10bb62de46c81982b1929ea7337da
parentedb3ab2a2a70ea2c9616b339382c977dbdf1a2ec (diff)
downloadphp-git-dc588997e202b5a645052bfb21098cc571693569.tar.gz
On Windows PHP may be restarted with different set of DSO extensions without SHM reset.
This may make optimisation for entities from DSO extensions inconsistent.
-rw-r--r--ext/opcache/Optimizer/pass1_5.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/ext/opcache/Optimizer/pass1_5.c b/ext/opcache/Optimizer/pass1_5.c
index ec6cf15c7f..2ae6b79b50 100644
--- a/ext/opcache/Optimizer/pass1_5.c
+++ b/ext/opcache/Optimizer/pass1_5.c
@@ -444,9 +444,13 @@ void zend_optimizer_pass1(zend_op_array *op_array, zend_optimizer_ctx *ctx)
zend_string *lc_name = zend_string_tolower(
Z_STR(ZEND_OP1_LITERAL(send1_opline)));
- if ((func = zend_hash_find_ptr(EG(function_table), lc_name)) != NULL &&
- func->type == ZEND_INTERNAL_FUNCTION &&
- func->module->type == MODULE_PERSISTENT) {
+ if ((func = zend_hash_find_ptr(EG(function_table), lc_name)) != NULL
+ && func->type == ZEND_INTERNAL_FUNCTION
+ && func->module->type == MODULE_PERSISTENT
+#ifdef ZEND_WIN32
+ && func->module->handle == NULL
+#endif
+ ) {
zval t;
if (Z_STRLEN(ZEND_OP2_LITERAL(init_opline)) == sizeof("is_callable") - 1 ||
func->handler != ZEND_FN(display_disabled_function)) {
@@ -483,7 +487,11 @@ void zend_optimizer_pass1(zend_op_array *op_array, zend_optimizer_ctx *ctx)
ZVAL_FALSE(&t);
}
} else {
- if (m->type == MODULE_PERSISTENT) {
+ if (m->type == MODULE_PERSISTENT
+#ifdef ZEND_WIN32
+ && m->handle == NULL
+#endif
+ ) {
ZVAL_TRUE(&t);
} else {
break;