dmitry Tue, 27 Jul 2010 09:50:35 +0000
Revision: http://svn.php.net/viewvc?view=revision&revision=301603
Log:
Additional specialization
Changed paths:
U php/php-src/trunk/Zend/zend_vm_def.h
U php/php-src/trunk/Zend/zend_vm_execute.h
Modified: php/php-src/trunk/Zend/zend_vm_def.h
===================================================================
--- php/php-src/trunk/Zend/zend_vm_def.h 2010-07-27 09:23:14 UTC (rev 301602)
+++ php/php-src/trunk/Zend/zend_vm_def.h 2010-07-27 09:50:35 UTC (rev 301603)
@@ -3751,7 +3751,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (OP1_TYPE == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (OP1_TYPE == IS_CV &&
+ OP2_TYPE == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -3955,7 +3957,8 @@
SAVE_OPLINE();
- if (opline->extended_value & ZEND_FE_RESET_VARIABLE) {
+ if ((OP1_TYPE == IS_CV || OP1_TYPE == IS_VAR) &&
+ (opline->extended_value & ZEND_FE_RESET_VARIABLE)) {
array_ptr_ptr = GET_OP1_ZVAL_PTR_PTR(BP_VAR_R);
if (array_ptr_ptr == NULL || array_ptr_ptr == &EG(uninitialized_zval_ptr)) {
MAKE_STD_ZVAL(array_ptr);
@@ -4257,7 +4260,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (OP1_TYPE == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (OP1_TYPE == IS_CV &&
+ OP2_TYPE == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
Modified: php/php-src/trunk/Zend/zend_vm_execute.h
===================================================================
--- php/php-src/trunk/Zend/zend_vm_execute.h 2010-07-27 09:23:14 UTC (rev 301602)
+++ php/php-src/trunk/Zend/zend_vm_execute.h 2010-07-27 09:50:35 UTC (rev 301603)
@@ -2170,7 +2170,8 @@
SAVE_OPLINE();
- if (opline->extended_value & ZEND_FE_RESET_VARIABLE) {
+ if ((IS_CONST == IS_CV || IS_CONST == IS_VAR) &&
+ (opline->extended_value & ZEND_FE_RESET_VARIABLE)) {
array_ptr_ptr = NULL;
if (array_ptr_ptr == NULL || array_ptr_ptr == &EG(uninitialized_zval_ptr)) {
MAKE_STD_ZVAL(array_ptr);
@@ -3167,7 +3168,9 @@
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -3230,7 +3233,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -4522,7 +4527,9 @@
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -4585,7 +4592,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -5030,7 +5039,9 @@
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -5093,7 +5104,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CONST == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CONST == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -6430,7 +6443,8 @@
SAVE_OPLINE();
- if (opline->extended_value & ZEND_FE_RESET_VARIABLE) {
+ if ((IS_TMP_VAR == IS_CV || IS_TMP_VAR == IS_VAR) &&
+ (opline->extended_value & ZEND_FE_RESET_VARIABLE)) {
array_ptr_ptr = NULL;
if (array_ptr_ptr == NULL || array_ptr_ptr == &EG(uninitialized_zval_ptr)) {
MAKE_STD_ZVAL(array_ptr);
@@ -7380,7 +7394,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -7443,7 +7459,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -8699,7 +8717,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -8762,7 +8782,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -9094,7 +9116,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -9157,7 +9181,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_TMP_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_TMP_VAR == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -10707,7 +10733,8 @@
SAVE_OPLINE();
- if (opline->extended_value & ZEND_FE_RESET_VARIABLE) {
+ if ((IS_VAR == IS_CV || IS_VAR == IS_VAR) &&
+ (opline->extended_value & ZEND_FE_RESET_VARIABLE)) {
array_ptr_ptr = _get_zval_ptr_ptr_var(opline->op1.var, EX_Ts(), &free_op1 TSRMLS_CC);
if (array_ptr_ptr == NULL || array_ptr_ptr == &EG(uninitialized_zval_ptr)) {
MAKE_STD_ZVAL(array_ptr);
@@ -12951,7 +12978,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -13150,7 +13179,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -17101,7 +17132,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -17300,7 +17333,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -18313,7 +18348,9 @@
zend_free_op free_op1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -18376,7 +18413,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_VAR == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_VAR == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -26355,7 +26394,8 @@
SAVE_OPLINE();
- if (opline->extended_value & ZEND_FE_RESET_VARIABLE) {
+ if ((IS_CV == IS_CV || IS_CV == IS_VAR) &&
+ (opline->extended_value & ZEND_FE_RESET_VARIABLE)) {
array_ptr_ptr = _get_zval_ptr_ptr_cv_BP_VAR_R(EX_CVs(), opline->op1.var TSRMLS_CC);
if (array_ptr_ptr == NULL || array_ptr_ptr == &EG(uninitialized_zval_ptr)) {
MAKE_STD_ZVAL(array_ptr);
@@ -28239,7 +28279,9 @@
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -28436,7 +28478,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_CONST == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -32136,7 +32180,9 @@
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -32333,7 +32379,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_VAR == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
@@ -33229,7 +33277,9 @@
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EG(active_symbol_table)) {
zend_compiled_variable *cv = &CV_DEF_OF(opline->op1.var);
@@ -33292,7 +33342,9 @@
zend_bool isset = 1;
SAVE_OPLINE();
- if (IS_CV == IS_CV && (opline->extended_value & ZEND_QUICK_SET)) {
+ if (IS_CV == IS_CV &&
+ IS_UNUSED == IS_UNUSED &&
+ (opline->extended_value & ZEND_QUICK_SET)) {
if (EX_CV(opline->op1.var)) {
value = EX_CV(opline->op1.var);
} else if (EG(active_symbol_table)) {
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php