Changeset 268 for trunk/xcache.c


Ignore:
Timestamp:
2006-10-29T03:05:01+01:00 (8 years ago)
Author:
moo
Message:

full compatible with auto_globals_jit, no need to disable it from now on

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/xcache.c

    r254 r268  
    500500            add_assoc_long_ex(ei, ZEND_STRS("function_cnt"),  php->funcinfo_cnt); 
    501501            add_assoc_long_ex(ei, ZEND_STRS("class_cnt"),     php->classinfo_cnt); 
     502#ifdef ZEND_ENGINE_2_1 
     503            add_assoc_long_ex(ei, ZEND_STRS("autoglobal_cnt"),php->autoglobal_cnt); 
     504#endif 
    502505            break; 
    503506        case XC_TYPE_VAR: 
     
    580583                UNISW(0, ci->type), ci->key, ci->key_size TSRMLS_CC); 
    581584    } 
     585 
     586#ifdef ZEND_ENGINE_2_1 
     587    /* trigger auto_globals jit */ 
     588    for (i = 0; i < p->autoglobal_cnt; i ++) { 
     589        xc_autoglobal_t *aginfo = &p->autoglobals[i]; 
     590        /* 
     591        zend_auto_global *auto_global; 
     592        if (zend_u_hash_find(CG(auto_globals), aginfo->type, aginfo->key, aginfo->key_len+1, (void **) &auto_global)==SUCCESS) { 
     593            if (auto_global->armed) { 
     594                auto_global->armed = auto_global->auto_global_callback(auto_global->name, auto_global->name_len TSRMLS_CC); 
     595            } 
     596        } 
     597        */ 
     598        zend_u_is_auto_global(aginfo->type, aginfo->key, aginfo->key_len TSRMLS_CC); 
     599    } 
     600#endif 
    582601 
    583602    i = 1; 
     
    949968 
    950969#ifdef HAVE_XCACHE_CONSTANT 
    951     php.constinfo_cnt = zend_hash_num_elements(EG(zend_constants)) - old_constinfo_cnt; 
    952 #endif 
    953     php.funcinfo_cnt  = zend_hash_num_elements(CG(function_table)) - old_funcinfo_cnt; 
    954     php.classinfo_cnt = zend_hash_num_elements(CG(class_table))    - old_classinfo_cnt; 
     970    php.constinfo_cnt  = zend_hash_num_elements(EG(zend_constants)) - old_constinfo_cnt; 
     971#endif 
     972    php.funcinfo_cnt   = zend_hash_num_elements(CG(function_table)) - old_funcinfo_cnt; 
     973    php.classinfo_cnt  = zend_hash_num_elements(CG(class_table))    - old_classinfo_cnt; 
     974#ifdef ZEND_ENGINE_2_1 
     975    /* {{{ count php.autoglobal_cnt */ { 
     976        Bucket *b; 
     977 
     978        php.autoglobal_cnt = 0; 
     979        for (b = CG(auto_globals)->pListHead; b != NULL; b = b->pListNext) { 
     980            zend_auto_global *auto_global = (zend_auto_global *) b->pData; 
     981            /* check if actived */ 
     982            if (auto_global->auto_global_callback && !auto_global->armed) { 
     983                php.autoglobal_cnt ++; 
     984            } 
     985        } 
     986    } 
     987    /* }}} */ 
     988#endif 
    955989 
    956990#define X_ALLOC_N(var, cnt) do {     \ 
     
    9671001 
    9681002#ifdef HAVE_XCACHE_CONSTANT 
    969     X_ALLOC_N(constinfos, constinfo_cnt); 
    970 #endif 
    971     X_ALLOC_N(funcinfos,  funcinfo_cnt); 
    972     X_ALLOC_N(classinfos, classinfo_cnt); 
     1003    X_ALLOC_N(constinfos,  constinfo_cnt); 
     1004#endif 
     1005    X_ALLOC_N(funcinfos,   funcinfo_cnt); 
     1006    X_ALLOC_N(classinfos,  classinfo_cnt); 
     1007#ifdef ZEND_ENGINE_2_1 
     1008    X_ALLOC_N(autoglobals, autoglobal_cnt); 
     1009#endif 
    9731010#undef X_ALLOC 
    9741011    /* }}} */ 
     
    10061043 
    10071044#undef COPY_H 
    1008         /* for ZE1, cest need to fix inside store */ 
     1045 
     1046        /* for ZE1, cest need to be fixed inside store */ 
     1047 
     1048#ifdef ZEND_ENGINE_2_1 
     1049        /* scan for acatived auto globals */ 
     1050        i = 0; 
     1051        for (b = CG(auto_globals)->pListHead; b != NULL; b = b->pListNext) { 
     1052            zend_auto_global *auto_global = (zend_auto_global *) b->pData; 
     1053            /* check if actived */ 
     1054            if (auto_global->auto_global_callback && !auto_global->armed) { 
     1055                xc_autoglobal_t *data = &php.autoglobals[i ++]; 
     1056 
     1057                assert(i < php.autoglobal_cnt); 
     1058                UNISW(NOTHING, data->type = b->key.type;) 
     1059                if (UNISW(1, b->key.type == IS_STRING)) { 
     1060                    ZSTR_S(data->key)     = BUCKET_KEY_S(b); 
     1061                } 
     1062                else { 
     1063                    ZSTR_U(data->key)     = BUCKET_KEY_U(b); 
     1064                } 
     1065                data->key_len = b->nKeyLength - 1; 
     1066            } 
     1067        } 
     1068#endif 
    10091069    } 
    10101070    /* }}} */ 
     
    10361096err_##var: 
    10371097 
     1098#ifdef ZEND_ENGINE_2_1 
     1099    X_FREE(autoglobals) 
     1100#endif 
    10381101    X_FREE(classinfos) 
    10391102    X_FREE(funcinfos) 
     
    11001163        efree(xce.data.php->var); \ 
    11011164    } 
     1165#ifdef ZEND_ENGINE_2_1 
     1166    X_FREE(autoglobals) 
     1167#endif 
    11021168    X_FREE(classinfos) 
    11031169    X_FREE(funcinfos) 
Note: See TracChangeset for help on using the changeset viewer.