source: trunk/processor/processor.m4 @ 779

Last change on this file since 779 was 779, checked in by moo, 3 years ago

cacher: fix segv if oplineinfo is used for __FILE __DIR

  • Property svn:eol-style set to native
File size: 27.9 KB
RevLine 
[1]1dnl ================
2/* {{{ Pre-declare */
3DECL_STRUCT_P_FUNC(`zval')
4DECL_STRUCT_P_FUNC(`zval_ptr')
5DECL_STRUCT_P_FUNC(`zend_op_array')
6DECL_STRUCT_P_FUNC(`zend_class_entry')
[95]7#ifdef HAVE_XCACHE_CONSTANT
8DECL_STRUCT_P_FUNC(`zend_constant')
9#endif
[1]10DECL_STRUCT_P_FUNC(`zend_function')
11DECL_STRUCT_P_FUNC(`xc_entry_t')
12#ifdef ZEND_ENGINE_2
13DECL_STRUCT_P_FUNC(`zend_property_info')
14#endif
15/* }}} */
16dnl ====================================================
17dnl {{{ zend_compiled_variable
18#ifdef IS_CV
19DEF_STRUCT_P_FUNC(`zend_compiled_variable', , `
20    DISPATCH(int, name_len)
[103]21    PROC_ZSTRING_L(, name, name_len)
[1]22    DISPATCH(ulong, hash_value)
23')
24#endif
25dnl }}}
26dnl {{{ zend_uint
27DEF_STRUCT_P_FUNC(`zend_uint', , `
28    IFCOPY(`dst[0] = src[0];')
29    IFDPRINT(`
30        INDENT()
31        fprintf(stderr, "%u\n", src[0]);
32    ')
33    DONE_SIZE(sizeof(src[0]))
34')
35dnl }}}
36dnl {{{ int
37#ifndef ZEND_ENGINE_2
38DEF_STRUCT_P_FUNC(`int', , `
39    IFCOPY(`*dst = *src;')
40    IFDPRINT(`
41        INDENT()
42        fprintf(stderr, "%d\n", src[0]);
43    ')
44    DONE_SIZE(sizeof(src[0]))
45')
46#endif
47dnl }}}
48dnl {{{ zend_try_catch_element
49#ifdef ZEND_ENGINE_2
50DEF_STRUCT_P_FUNC(`zend_try_catch_element', , `
51    DISPATCH(zend_uint, try_op)
52    DISPATCH(zend_uint, catch_op)
53')
54#endif /* ifdef ZEND_ENGINE_2 */
55dnl }}}
56dnl {{{ zend_brk_cont_element
57DEF_STRUCT_P_FUNC(`zend_brk_cont_element', , `
[194]58#ifdef ZEND_ENGINE_2_2
59    DISPATCH(int, start)
60#endif
[1]61    DISPATCH(int, cont)
62    DISPATCH(int, brk)
63    DISPATCH(int, parent)
64')
65dnl }}}
66DEF_HASH_TABLE_FUNC(`HashTable_zval_ptr',           `zval_ptr')
67DEF_HASH_TABLE_FUNC(`HashTable_zend_function',      `zend_function')
68#ifdef ZEND_ENGINE_2
69DEF_HASH_TABLE_FUNC(`HashTable_zend_property_info', `zend_property_info')
70#endif
71DEF_STRUCT_P_FUNC(`zval', , `dnl {{{
72    IFDASM(`do {
73        zval_dtor(dst);
74        *dst = *src;
75        zval_copy_ctor(dst);
[487]76        Z_SET_REFCOUNT(*dst, 1);
[1]77        DONE(value)
78        DONE(type)
[485]79#ifdef ZEND_ENGINE_2_3
80        DONE(is_ref__gc)
81        DONE(refcount__gc)
82#else
[1]83        DONE(is_ref)
[485]84        DONE(refcount)
[482]85#endif
[1]86    } while(0);
87    ', `
88        dnl IFDASM else
89        /* Variable information */
90dnl {{{ zvalue_value
91        DISABLECHECK(`
[491]92        switch ((Z_TYPE_P(src) & IS_CONSTANT_TYPE_MASK)) {
[1]93            case IS_LONG:
94            case IS_RESOURCE:
95            case IS_BOOL:
96                DISPATCH(long, value.lval)
97                break;
98            case IS_DOUBLE:
99                DISPATCH(double, value.dval)
100                break;
101            case IS_NULL:
102                IFDPRINT(`INDENT()`'fprintf(stderr, "\tNULL\n");')
103                break;
104
105            case IS_CONSTANT:
106#ifdef IS_UNICODE
107                if (UG(unicode)) {
108                    goto proc_unicode;
109                }
110#endif
111            case IS_STRING:
112#ifdef FLAG_IS_BC
113            case FLAG_IS_BC:
114#endif
115                DISPATCH(int, value.str.len)
116                PROC_STRING_L(value.str.val, value.str.len)
117                break;
118#ifdef IS_UNICODE
119            case IS_UNICODE:
120proc_unicode:
[103]121                DISPATCH(int32_t, value.uni.len)
122                PROC_ZSTRING_L(1, value.uni.val, value.uni.len)
[1]123                break;
124#endif
125
126            case IS_ARRAY:
127            case IS_CONSTANT_ARRAY:
128                STRUCT_P(HashTable, value.ht, HashTable_zval_ptr)
129                break;
130
131            case IS_OBJECT:
132                IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
133                dnl STRUCT(value.obj)
134#ifndef ZEND_ENGINE_2
135                STRUCT_P(zend_class_entry, value.obj.ce)
136                STRUCT_P(HashTable, value.obj.properties, HashTable_zval_ptr)
137#endif
138                break;
139
140            default:
141                assert(0);
142        }
143        ')
144dnl }}}
145        DONE(value)
146        DISPATCH(zval_data_type, type)
[485]147#ifdef ZEND_ENGINE_2_3
148        DISPATCH(zend_uchar, is_ref__gc)
149#else
[1]150        DISPATCH(zend_uchar, is_ref)
[485]151#endif
152
153#ifdef ZEND_ENGINE_2_3
154        DISPATCH(zend_uint, refcount__gc)
155#elif defined(ZEND_ENGINE_2)
[484]156        DISPATCH(zend_uint, refcount)
157#else
[1]158        DISPATCH(zend_ushort, refcount)
[484]159#endif
[1]160    ')dnl IFDASM
161')
162dnl }}}
163DEF_STRUCT_P_FUNC(`zval_ptr', , `dnl {{{
164    IFDASM(`
165        pushdefFUNC_NAME(`zval')
166        FUNC_NAME (dst, src[0] TSRMLS_CC);
167        popdef(`FUNC_NAME')
168    ', `
169        do {
170            IFCALCCOPY(`
171                if (processor->reference) {
172                    zval_ptr *ppzv;
[231]173                    if (zend_hash_find(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void **) &ppzv) == SUCCESS) {
[1]174                        IFCOPY(`
175                            dst[0] = *ppzv;
176                            /* *dst is updated */
[248]177                            dnl fprintf(stderr, "*dst is set to %p, KIND is_shm %d\n", dst[0], xc_is_shm(dst[0]));
[1]178                        ')
[233]179                        IFCALCSTORE(`processor->have_references = 1;')
[1]180                        IFSTORE(`assert(xc_is_shm(dst[0]));')
181                        IFRESTORE(`assert(!xc_is_shm(dst[0]));')
182                        break;
183                    }
184                }
185            ')
186           
187            ALLOC(dst[0], zval)
188            IFCALCCOPY(`
189                if (processor->reference) {
190                    IFCALC(`
191                        /* make dummy */
192                        zval_ptr pzv = (zval_ptr)-1;
193                    ', `
194                        zval_ptr pzv = dst[0];
[248]195                        FIXPOINTER_EX(zval, pzv)
[1]196                    ')
[231]197                    if (zend_hash_add(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void *) &pzv, sizeof(pzv), NULL) == SUCCESS) {
[1]198                        /* first add, go on */
199                        dnl fprintf(stderr, "mark[%p] = %p\n", src[0], pzv);
200                    }
201                    else {
202                        assert(0);
203                    }
204                }
205            ')
206            IFCOPY(`
207                dnl fprintf(stderr, "copy from %p to %p\n", src[0], dst[0]);
208            ')
[534]209            IFDPRINT(`INDENT()`'fprintf(stderr, "[%p] ", src[0]);')
[4]210            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
[248]211            FIXPOINTER_EX(zval, dst[0])
[1]212        } while (0);
213    ')
214    DONE_SIZE(sizeof(zval_ptr))
215')
216dnl }}}
217dnl {{{ zend_arg_info
218#ifdef ZEND_ENGINE_2
219DEF_STRUCT_P_FUNC(`zend_arg_info', , `
220    DISPATCH(zend_uint, name_len)
[645]221    PROC_ZSTRING_L(, name, name_len)
[1]222    DISPATCH(zend_uint, class_name_len)
[645]223    PROC_ZSTRING_L(, class_name, class_name_len)
[716]224#ifdef ZEND_ENGINE_2_4
225    DISPATCH(zend_uchar, type_hint)
226#else
[1]227    DISPATCH(zend_bool, array_type_hint)
[716]228#endif
[1]229    DISPATCH(zend_bool, allow_null)
230    DISPATCH(zend_bool, pass_by_reference)
[716]231#ifndef ZEND_ENGINE_2_4
[1]232    DISPATCH(zend_bool, return_reference)
233    DISPATCH(int, required_num_args)
[716]234#endif
[1]235')
236#endif
237dnl }}}
[95]238#ifdef HAVE_XCACHE_CONSTANT
239DEF_STRUCT_P_FUNC(`zend_constant', , `dnl {{{
240    STRUCT(zval, value)
241    DISPATCH(int, flags)
242    DISPATCH(uint, name_len)
[218]243    pushdef(`emalloc', `malloc($1)')
244    pushdef(`ecalloc', `calloc($1, $2)')
[505]245    PROC_ZSTRING_N(, name, name_len)
[218]246    popdef(`ecalloc')
247    popdef(`emalloc')
[95]248    DISPATCH(int, module_number)
249')
250dnl }}}
251#endif
[1]252DEF_STRUCT_P_FUNC(`zend_function', , `dnl {{{
253    DISABLECHECK(`
254    switch (src->type) {
255    case ZEND_INTERNAL_FUNCTION:
256    case ZEND_OVERLOADED_FUNCTION:
257        IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
258        break;
259
260    case ZEND_USER_FUNCTION:
261    case ZEND_EVAL_CODE:
262        DONE(type)
263        STRUCT(zend_op_array, op_array)
264        break;
265
266    default:
267        assert(0);
268    }
269    ')
270    DONE_SIZE(sizeof(src[0]))
271')
272dnl }}}
273dnl {{{ zend_property_info
274#ifdef ZEND_ENGINE_2
275DEF_STRUCT_P_FUNC(`zend_property_info', , `
276    DISPATCH(zend_uint, flags)
277    DISPATCH(int, name_length)
[103]278    PROC_ZSTRING_L(, name, name_length)
[1]279    DISPATCH(ulong, h)
[716]280#ifdef ZEND_ENGINE_2_4
281    DISPATCH(int, offset)
282#endif
[56]283#ifdef ZEND_ENGINE_2_1
[1]284    DISPATCH(int, doc_comment_len)
[272]285    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
[56]286#endif
[78]287    dnl isnt in php6 yet
[504]288#if defined(ZEND_ENGINE_2_2)
[78]289    PROC_CLASS_ENTRY_P(ce)
290#endif
[1]291')
292#endif
293dnl }}}
294DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
[199]295    IFCALCCOPY(`
[1]296        processor->active_class_entry_src = src;
[199]297        IFCOPY(`processor->active_class_entry_dst = dst;')
[1]298    ')
299    DISPATCH(char, type)
300    DISPATCH(zend_uint, name_length)
[103]301    PROC_ZSTRING_L(, name, name_length)
[1]302    IFRESTORE(`
303#ifndef ZEND_ENGINE_2
304        /* just copy parent and resolve on install_class */
305        COPY(parent)
306#else
307        PROC_CLASS_ENTRY_P(parent)
308#endif
309    ', `
310        PROC_CLASS_ENTRY_P(parent)
311    ')
312#ifdef ZEND_ENGINE_2
313    DISPATCH(int, refcount)
314#else
315    STRUCT_P(int, refcount)
316#endif
[716]317#ifndef ZEND_ENGINE_2_4
[1]318    DISPATCH(zend_bool, constants_updated)
[716]319#endif
[1]320#ifdef ZEND_ENGINE_2
321    DISPATCH(zend_uint, ce_flags)
322#endif
323
[721]324#ifdef ZEND_ENGINE_2
325    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
326#endif
327
[716]328#ifdef ZEND_ENGINE_2_4
329    DISPATCH(int, default_properties_count)
[730]330    STRUCT_ARRAY(default_properties_count, zval_ptr, default_properties_table)
[716]331    DISPATCH(int, default_static_members_count)
[730]332    STRUCT_ARRAY(default_static_members_count, zval_ptr, default_static_members_table)
333    IFCOPY(`dst->static_members_table = dst->default_static_members_table;')
[716]334    DONE(static_members_table)
335#else
[1]336    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
337    DONE(builtin_functions)
[716]338    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
[721]339#   ifdef ZEND_ENGINE_2_1
[233]340    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
[1]341    IFCOPY(`dst->static_members = &dst->default_static_members;')
342    DONE(static_members)
[721]343#   elif defined(ZEND_ENGINE_2)
[233]344    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
[1]345#   endif
[716]346#endif /* ZEND_ENGINE_2_4 */
347
348#ifdef ZEND_ENGINE_2
[1]349    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
350
351    dnl runtime binding: ADD_INTERFACE will deal with it
[716]352    dnl runtime binding: ADD_TRAIT will deal with it
[1]353    IFRESTORE(`
354        if (src->num_interfaces) {
355            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
[4]356            DONE(`interfaces')
[716]357#   ifdef ZEND_ENGINE_2_4
358            CALLOC(dst->traits, zend_class_entry*, src->num_traits)
359            DONE(`traits')
360            DONE(`trait_aliases')
361            DONE(`trait_precedences')
362#   endif
[1]363        }
364        else {
[716]365            COPYNULL(`interfaces')
366#   ifdef ZEND_ENGINE_2_4
367            COPYNULL(`traits')
368            COPYNULL(`trait_aliases')
369            COPYNULL(`trait_precedences')
370#   endif
[1]371        }
372    ')
373    IFDASM(`
374        if (src->num_interfaces) {
375            /*
[662]376            int i;
[1]377            zval *arr;
378            ALLOC_INIT_ZVAL(arr);
379            array_init(arr);
380            for (i = 0; i < src->num_interfaces; i ++) {
381                zval *zv;
382                ALLOC_INIT_ZVAL(zv);
383                ZVAL_STRING(src->num_interfaces);
384            }
385            add_assoc_zval_ex(dst, ZEND_STRS("interfaces"), arr);
386            */
[4]387            DONE(`interfaces')
[716]388#   ifdef ZEND_ENGINE_2_4
389            DONE(`traits')
390            DONE(`trait_aliases')
391            DONE(`trait_precedences')
392#   endif
[1]393        }
394        else {
[716]395            COPYNULL(`interfaces')
396#   ifdef ZEND_ENGINE_2_4
397            COPYNULL(`traits')
398            COPYNULL(`trait_aliases')
399            COPYNULL(`trait_precedences')
400#   endif
[1]401        }
402    ')
[4]403    IFRESTORE(`', `
404        IFDASM(`', `
405            DONE(`interfaces')
[716]406#   ifdef ZEND_ENGINE_2_4
407            DONE(`traits')
408            DONE(`trait_aliases')
409            DONE(`trait_precedences')
410#   endif
[4]411        ')
412    ')
[1]413    DISPATCH(zend_uint, num_interfaces)
[716]414#   ifdef ZEND_ENGINE_2_4
415    DISPATCH(zend_uint, num_traits)
416#   endif
[1]417
[716]418#   ifdef ZEND_ENGINE_2_4
419    DISABLECHECK(`
420    IFRESTORE(`dst->info.user.filename = processor->entry_src->filepath;', `PROC_STRING(info.user.filename)')
421    DISPATCH(zend_uint, info.user.line_start)
422    DISPATCH(zend_uint, info.user.line_end)
423    DISPATCH(zend_uint, info.user.doc_comment_len)
424    PROC_ZSTRING_L(, info.user.doc_comment, info.user.doc_comment_len)
425    ')
426    DONE(info)
427#   else
[687]428    IFRESTORE(`dst->filename = processor->entry_src->filepath;DONE(filename)', `PROC_STRING(filename)')
[1]429    DISPATCH(zend_uint, line_start)
430    DISPATCH(zend_uint, line_end)
[716]431#       ifdef ZEND_ENGINE_2_1
[1]432    DISPATCH(zend_uint, doc_comment_len)
[272]433    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
[716]434#       endif
435#   endif
436
[1]437    /* # NOT DONE */
438    COPY(serialize_func)
439    COPY(unserialize_func)
440    COPY(iterator_funcs)
441    COPY(create_object)
442    COPY(get_iterator)
443    COPY(interface_gets_implemented)
[716]444#   ifdef ZEND_ENGINE_2_3
[480]445    COPY(get_static_method)
[716]446#   endif
[1]447    COPY(serialize)
448    COPY(unserialize)
449    /* deal with it inside xc_fix_method */
450    SETNULL(constructor)
451    COPY(destructor)
452    COPY(clone)
453    COPY(__get)
454    COPY(__set)
455/* should be >5.1 */
[716]456#   ifdef ZEND_ENGINE_2_1
[1]457    COPY(__unset)
458    COPY(__isset)
[716]459#    if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
[1]460    COPY(__tostring)
[716]461#    endif
462#   endif
[1]463    COPY(__call)
[716]464#   ifdef ZEND_CALLSTATIC_FUNC_NAME
[480]465    COPY(__callstatic)
[716]466#   endif
467#   ifndef ZEND_ENGINE_2_4
[1]468    /* # NOT DONE */
469    COPY(module)
[716]470#   endif
471#else /* ZEND_ENGINE_2 */
[1]472    COPY(handle_function_call)
473    COPY(handle_property_get)
474    COPY(handle_property_set)
475#endif
[89]476    dnl must do after SETNULL(constructor) and dst->parent
[1]477    STRUCT(HashTable, function_table, HashTable_zend_function)
[99]478    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
[199]479    IFCALCCOPY(`
[89]480        processor->active_class_entry_src = NULL;
[199]481        IFCOPY(`processor->active_class_entry_dst = NULL;')
[89]482    ')
[1]483')
484dnl }}}
[716]485#ifdef ZEND_ENGINE_2_4
486undefine(`UNION_znode_op')
487define(`UNION_znode_op', `dnl {{{
[721]488    switch ((src->$1_type & ~EXT_TYPE_UNUSED)) {
489    case IS_CONST:
490    case IS_VAR:
491    case IS_CV:
492    case IS_TMP_VAR:
493    case IS_UNUSED:
494        break;
495
496    default:
497        assert(0);
498    }
499
[716]500    dnl dirty dispatch
501    DISABLECHECK(`
[721]502    switch ((src->$1_type & ~EXT_TYPE_UNUSED)) {
[716]503        case IS_CONST:
504            dnl TODO: fix me, use literals
505            IFDASM(`{
506                zval *zv;
507                ALLOC_INIT_ZVAL(zv);
508                *zv = ((zend_literal *) src->$1.ptr)->constant;
509                zval_copy_ctor(zv);
510                add_assoc_zval_ex(dst, ZEND_STRS("$1.constant"), zv);
511                }
512            ', `
513                DISPATCH(zend_uint, $1.constant)
514            ')
515            break;
516        IFCOPY(`
517            IFNOTMEMCPY(`
518                default:
519                    *dst = *src;
520            ')
521        ', `
522        case IS_VAR:
523        case IS_TMP_VAR:
524        case IS_CV:
525            DISPATCH(zend_uint, $1.var)
526            break;
527        case IS_UNUSED:
528            IFDASM(`DISPATCH(zend_uint, $1.var)')
529            DISPATCH(zend_uint, $1.opline_num)
530            break;
531        ')
532    }
533    ')
534    DONE($1)
535')
536dnl }}}
537#else
[1]538DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
539    DISPATCH(int, op_type)
540
541#ifdef IS_CV
[11]542#   define XCACHE_IS_CV IS_CV
[1]543#else
[11]544/* compatible with zend optimizer */
545#   define XCACHE_IS_CV 16
[1]546#endif
[11]547    assert(src->op_type == IS_CONST ||
548        src->op_type == IS_VAR ||
549        src->op_type == XCACHE_IS_CV ||
[1]550        src->op_type == IS_TMP_VAR ||
551        src->op_type == IS_UNUSED);
552    dnl dirty dispatch
553    DISABLECHECK(`
554    switch (src->op_type) {
555        case IS_CONST:
556            STRUCT(zval, u.constant)
557            break;
558        IFCOPY(`
559            IFNOTMEMCPY(`
560                default:
561                    memcpy(&dst->u, &src->u, sizeof(src->u));
562            ')
563        ', `
564        case IS_VAR:
565        case IS_TMP_VAR:
[310]566        case XCACHE_IS_CV:
[1]567            DISPATCH(zend_uint, u.var)
568            DISPATCH(zend_uint, u.EA.type)
569            break;
570        case IS_UNUSED:
571            IFDASM(`DISPATCH(zend_uint, u.var)')
572            DISPATCH(zend_uint, u.opline_num)
573#ifndef ZEND_ENGINE_2
574            DISPATCH(zend_uint, u.fetch_type)
575#endif
576            DISPATCH(zend_uint, u.EA.type)
577            break;
578        ')
579    }
580    ')
581    DONE(u)
[716]582#if 0
583    DONE(EA)
584#endif
[310]585#undef XCACHE_IS_CV
[1]586')
587dnl }}}
[716]588#endif
[1]589DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
590    DISPATCH(zend_uchar, opcode)
[716]591#ifdef ZEND_ENGINE_2_4
592    UNION_znode_op(result)
593    UNION_znode_op(op1)
594    UNION_znode_op(op2)
595#else
[1]596    STRUCT(znode, result)
597    STRUCT(znode, op1)
598    STRUCT(znode, op2)
[716]599#endif
[1]600    DISPATCH(ulong, extended_value)
601    DISPATCH(uint, lineno)
602#ifdef ZEND_ENGINE_2_1
[716]603#ifdef ZEND_ENGINE_2_4
604    DISPATCH(zend_uchar, op1_type)
605    DISPATCH(zend_uchar, op2_type)
606    DISPATCH(zend_uchar, result_type)
607#endif
[1]608    IFCOPY(`
609        switch (src->opcode) {
[515]610#ifdef ZEND_GOTO
611            case ZEND_GOTO:
612#endif
[1]613            case ZEND_JMP:
[779]614                assert(Z_OP(src->op1).jmp_addr > processor->active_opcodes_src && Z_OP(src->op1).jmp_addr - processor->active_opcodes_src < processor->active_op_array_src->last);
[716]615                Z_OP(dst->op1).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op1).jmp_addr - processor->active_opcodes_src);
[779]616                assert(Z_OP(dst->op1).jmp_addr > processor->active_opcodes_dst && Z_OP(dst->op1).jmp_addr - processor->active_opcodes_dst < processor->active_op_array_dst->last);
[1]617                break;
618
619            case ZEND_JMPZ:
620            case ZEND_JMPNZ:
621            case ZEND_JMPZ_EX:
622            case ZEND_JMPNZ_EX:
[485]623#ifdef ZEND_JMP_SET
624            case ZEND_JMP_SET:
625#endif
[779]626                assert(Z_OP(src->op2).jmp_addr > processor->active_opcodes_src && Z_OP(src->op2).jmp_addr - processor->active_opcodes_src < processor->active_op_array_src->last);
[716]627                Z_OP(dst->op2).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op2).jmp_addr - processor->active_opcodes_src);
[779]628                assert(Z_OP(dst->op2).jmp_addr > processor->active_opcodes_dst && Z_OP(dst->op2).jmp_addr - processor->active_opcodes_dst < processor->active_op_array_dst->last);
[1]629                break;
630
631            default:
632                break;
633        }
634    ')
635    DISPATCH(opcode_handler_t, handler)
636#endif
637')
638dnl }}}
[716]639#ifdef ZEND_ENGINE_2_4
640DEF_STRUCT_P_FUNC(`zend_literal', , `dnl {{{
641    STRUCT(zval, constant)
642    DISPATCH(zend_ulong, hash_value)
643    DISPATCH(zend_uint,  cache_slot)
644')
645dnl }}}
646#endif
[1]647DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
648    IFRESTORE(`
[771]649    const xc_op_array_info_t *op_array_info = &processor->active_op_array_infos_src[processor->active_op_array_index++];
[212]650    dnl shadow copy must NOT meet:
651    dnl readonly_protection=on
652    dnl main op_array && have early binding
[548]653#ifdef ZEND_COMPILE_DELAYED_BINDING
654    zend_bool need_early_binding = 0;
655#else
656    zend_bool need_early_binding = processor->php_src->have_early_binding;
657#endif
[662]658    zend_bool shallow_copy = !processor->readonly_protection && !(src == processor->php_src->op_array && need_early_binding);
659    if (shallow_copy) {
660        zend_bool gc_arg_info = 0;
661        int gc_opcodes        = 0;
[1]662        /* really fast shallow copy */
663        memcpy(dst, src, sizeof(src[0]));
664        dst->refcount[0] = 1000;
665        /* deep */
666        STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
[508]667#ifdef ZEND_ENGINE_2
[662]668        STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
669        gc_arg_info = 1;
[508]670#endif
[687]671        IFRESTORE(`dst->filename = processor->entry_src->filepath;')
[721]672#ifndef ZEND_ENGINE_2_4
[662]673        if (op_array_info->oplineinfo_cnt) {
[779]674            zend_op *opline, *end;
[662]675            gc_opcodes = 1;
676            COPY_N_EX(last, zend_op, opcodes)
[779]677
678            for (opline = dst->opcodes, end = opline + src->last; opline < end; ++opline) {
679                switch (opline->opcode) {
680#ifdef ZEND_GOTO
681                    case ZEND_GOTO:
682#endif
683                    case ZEND_JMP:
684                        Z_OP(opline->op1).jmp_addr = dst->opcodes + (Z_OP(opline->op1).jmp_addr - src->opcodes);
685                        break;
686
687                    case ZEND_JMPZ:
688                    case ZEND_JMPNZ:
689                    case ZEND_JMPZ_EX:
690                    case ZEND_JMPNZ_EX:
691#ifdef ZEND_JMP_SET
692                    case ZEND_JMP_SET:
693#endif
694                        Z_OP(opline->op2).jmp_addr = dst->opcodes + (Z_OP(opline->op2).jmp_addr - src->opcodes);
695                        break;
696
697                    default:
698                        break;
699                }
700            }
[662]701        }
[721]702#endif
[662]703        if (gc_arg_info || gc_opcodes) {
704            xc_gc_op_array_t gc_op_array;
705#ifdef ZEND_ENGINE_2
706            gc_op_array.num_args = gc_arg_info ? dst->num_args : 0;
707            gc_op_array.arg_info = gc_arg_info ? dst->arg_info : NULL;
708#endif
709            gc_op_array.last     = gc_opcodes > 1 ? dst->last : 0;
710            gc_op_array.opcodes  = gc_opcodes ? dst->opcodes : NULL;
711            xc_gc_add_op_array(&gc_op_array TSRMLS_CC);
712        }
[1]713        define(`SKIPASSERT_ONCE')
714    }
715    else
716    ')
717    do {
718    dnl RESTORE is done above!
719
720    /* Common elements */
721    DISPATCH(zend_uchar, type)
[103]722    PROC_ZSTRING(, function_name)
[1]723#ifdef ZEND_ENGINE_2
724    DISPATCH(zend_uint, fn_flags)
[662]725    STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
[1]726    DISPATCH(zend_uint, num_args)
727    DISPATCH(zend_uint, required_num_args)
[716]728#   ifndef ZEND_ENGINE_2_4
[1]729    DISPATCH(zend_bool, pass_rest_by_reference)
[716]730#   endif
[1]731#else
732    if (src->arg_types) {
733        ALLOC(dst->arg_types, zend_uchar, src->arg_types[0] + 1)
734        IFCOPY(`memcpy(dst->arg_types, src->arg_types, sizeof(src->arg_types[0]) * (src->arg_types[0]+1));')
735        IFDASM(`do {
736            int i;
737            zval *zv;
738            ALLOC_INIT_ZVAL(zv);
739            array_init(zv);
740            for (i = 0; i < src->arg_types[0]; i ++) {
741                add_next_index_long(zv, src->arg_types[i + 1]);
742            }
743            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
744        } while (0);')
745        DONE(arg_types)
746    }
747    else {
748        IFDASM(`do {
749            /* empty array */
750            zval *zv;
751            ALLOC_INIT_ZVAL(zv);
752            array_init(zv);
753            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
754        } while (0);
755        DONE(arg_types)
756        ', `
757        COPYNULL(arg_types)
758        ')
759    }
760#endif
[716]761#ifndef ZEND_ENGINE_2_4
[1]762    DISPATCH(unsigned char, return_reference)
[716]763#endif
[1]764    /* END of common elements */
765#ifdef IS_UNICODE
[103]766    dnl SETNULL(u_twin)
[1]767#endif
768
769    STRUCT_P(zend_uint, refcount)
770    UNFIXPOINTER(zend_uint, refcount)
[221]771    IFSTORE(`dst->refcount[0] = 1;')
[1]772
773    pushdef(`AFTER_ALLOC', `IFCOPY(`
[779]774#ifndef NDEBUG
775        processor->active_op_array_dst = dst;
776        processor->active_op_array_src = src;
777#endif
[1]778        processor->active_opcodes_dst = dst->opcodes;
779        processor->active_opcodes_src = src->opcodes;
780    ')')
[662]781    STRUCT_ARRAY(last, zend_op, opcodes)
[1]782    popdef(`AFTER_ALLOC')
783    DISPATCH(zend_uint, last)
[716]784#ifndef ZEND_ENGINE_2_4
[1]785    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
[716]786#endif
[1]787
788#ifdef IS_CV
789    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
790    DISPATCH(int, last_var)
[716]791#   ifndef ZEND_ENGINE_2_4
[1]792    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
[716]793#   endif
[1]794#else
795    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
796    IFDASM(`
[4]797        sinclude(srcdir`/processor/zend_cv.m4')
[1]798        ')
799#endif
800
801    DISPATCH(zend_uint, T)
802
[662]803    STRUCT_ARRAY(last_brk_cont, zend_brk_cont_element, brk_cont_array)
[1]804    DISPATCH(zend_uint, last_brk_cont)
[716]805#ifndef ZEND_ENGINE_2_4
[1]806    DISPATCH(zend_uint, current_brk_cont)
[716]807#endif
[1]808#ifndef ZEND_ENGINE_2
809    DISPATCH(zend_bool, uses_globals)
810#endif
811
812#ifdef ZEND_ENGINE_2
813    STRUCT_ARRAY(last_try_catch, zend_try_catch_element, try_catch_array)
814    DISPATCH(int, last_try_catch)
815#endif
816
817    STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
818
[716]819#ifndef ZEND_ENGINE_2_4
[95]820    COPY(start_op)
[1]821    DISPATCH(int, backpatch_count)
[716]822#endif
[562]823#ifdef ZEND_ENGINE_2_3
824    DISPATCH(zend_uint, this_var)
825#endif
[1]826
[716]827#ifndef ZEND_ENGINE_2_4
[1]828    DISPATCH(zend_bool, done_pass_two)
[716]829#endif
[562]830    /* 5.0 <= ver < 5.3 */
831#if defined(ZEND_ENGINE_2) && !defined(ZEND_ENGINE_2_3)
[1]832    DISPATCH(zend_bool, uses_this)
833#endif
834
[687]835    IFRESTORE(`dst->filename = processor->entry_src->filepath;DONE(filename)', `PROC_STRING(filename)')
[1]836#ifdef IS_UNICODE
[267]837    IFRESTORE(`
838        COPY(script_encoding)
839    ', `
840        PROC_STRING(script_encoding)
841    ')
[1]842#endif
843#ifdef ZEND_ENGINE_2
844    DISPATCH(zend_uint, line_start)
845    DISPATCH(zend_uint, line_end)
846    DISPATCH(int, doc_comment_len)
[272]847    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
[1]848#endif
[548]849#ifdef ZEND_COMPILE_DELAYED_BINDING
850    DISPATCH(zend_uint, early_binding);
851#endif
[1]852
853    /* reserved */
854    DONE(reserved)
855#if defined(HARDENING_PATCH) && HARDENING_PATCH
856    DISPATCH(zend_bool, created_by_eval)
857#endif
[724]858#ifdef ZEND_ENGINE_2_4
859    DISPATCH(int, last_literal)
860    IFRESTORE(`COPY(literals)', `STRUCT_ARRAY(last_literal, zend_literal, literals)')
861
862    COPYNULL(run_time_cache)
863    COPYNULL(last_cache_slot)
864#endif
[1]865    } while (0);
[684]866    IFRESTORE(`xc_fix_op_array_info(processor->entry_src, processor->php_src, dst, !shallow_copy, op_array_info TSRMLS_CC);')
[189]867
[219]868#ifdef ZEND_ENGINE_2
869    dnl mark it as -1 on store, and lookup parent on restore
870    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
871            IFRESTORE(`do {
872                zend_function *parent;
873                if (src->prototype != NULL
874                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
875                        UG(unicode) ? IS_UNICODE : IS_STRING,
[513]876                        src->function_name, xc_zstrlen(UG(unicode) ? IS_UNICODE : IS_STRING, src->function_name) + 1,
[219]877                        (void **) &parent) == SUCCESS) {
878                    /* see do_inherit_method_check() */
879                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
880                      dst->prototype = parent;
881                    } else if (!(parent->common.fn_flags & ZEND_ACC_CTOR) || (parent->common.prototype && (parent->common.prototype->common.scope->ce_flags & ZEND_ACC_INTERFACE))) {
882                        /* ctors only have a prototype if it comes from an interface */
883                        dst->prototype = parent->common.prototype ? parent->common.prototype : parent;
884                    }
885                    else {
886                        dst->prototype = NULL;
887                    }
888                }
889                else {
890                    dst->prototype = NULL;
891                }
892                DONE(prototype)
893            } while (0);
894            ', `
895                COPYNULL(prototype)
896            ')
897    ')
[716]898
[219]899#endif
900
[189]901#ifdef ZEND_ENGINE_2
[507]902    PROC_CLASS_ENTRY_P(scope)
903    IFCOPY(`
[219]904        if (src->scope) {
[507]905            xc_fix_method(processor, dst TSRMLS_CC);
[189]906        }
907    ')
[507]908#endif
[189]909
910    IFRESTORE(`
911        if (xc_have_op_array_ctor) {
912            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
913        }
914    ')
[1]915')
916dnl }}}
917
[95]918#ifdef HAVE_XCACHE_CONSTANT
919DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
920    DISPATCH(zend_uint, key_size)
921#ifdef IS_UNICODE
922    DISPATCH(zend_uchar, type)
923#endif
924    IFRESTORE(`COPY(key)', `
[103]925        PROC_ZSTRING_N(type, key, key_size)
[95]926    ')
[506]927    DISPATCH(ulong, h)
[95]928    STRUCT(zend_constant, constant)
929')
930dnl }}}
931#endif
[662]932DEF_STRUCT_P_FUNC(`xc_op_array_info_t', , `dnl {{{
[721]933#ifdef ZEND_ENGINE_2_4
934    DISPATCH(zend_uint, literalinfo_cnt)
935    DISPATCH_ARRAY(literalinfo_cnt, int, literalinfos)
936#else
[662]937    DISPATCH(zend_uint, oplineinfo_cnt)
938    DISPATCH_ARRAY(oplineinfo_cnt, int, oplineinfos)
[721]939#endif
[662]940')
941dnl }}}
[1]942DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
943    DISPATCH(zend_uint, key_size)
944#ifdef IS_UNICODE
945    DISPATCH(zend_uchar, type)
946#endif
947    IFRESTORE(`COPY(key)', `
[103]948        PROC_ZSTRING_N(type, key, key_size)
[1]949    ')
[506]950    DISPATCH(ulong, h)
[662]951    IFRESTORE(`COPY(op_array_info)', `
952        STRUCT(xc_op_array_info_t, op_array_info)
953    ')
954    IFRESTORE(`
[666]955        processor->active_op_array_infos_src = &src->op_array_info;
[662]956        processor->active_op_array_index = 0;
957    ')
[1]958    STRUCT(zend_function, func)
959')
960dnl }}}
961DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
962    DISPATCH(zend_uint, key_size)
963#ifdef IS_UNICODE
964    DISPATCH(zend_uchar, type)
965#endif
966    IFRESTORE(`COPY(key)', `
[103]967        PROC_ZSTRING_N(type, key, key_size)
[1]968    ')
[506]969    DISPATCH(ulong, h)
[662]970    DISPATCH(zend_uint, methodinfo_cnt)
971    IFRESTORE(`COPY(methodinfos)', `
972        STRUCT_ARRAY(methodinfo_cnt, xc_op_array_info_t, methodinfos)
973    ')
974    IFRESTORE(`
[666]975        processor->active_op_array_infos_src = src->methodinfos;
[662]976        processor->active_op_array_index = 0;
977    ')
[1]978#ifdef ZEND_ENGINE_2
979    STRUCT_P(zend_class_entry, cest)
980#else
981    STRUCT(zend_class_entry, cest)
982#endif
[548]983#ifndef ZEND_COMPILE_DELAYED_BINDING
[212]984    DISPATCH(int, oplineno)
[548]985#endif
[1]986')
987dnl }}}
[268]988#ifdef ZEND_ENGINE_2_1
989DEF_STRUCT_P_FUNC(`xc_autoglobal_t', , `dnl {{{
990    DISPATCH(zend_uint, key_len)
991#ifdef IS_UNICODE
992    DISPATCH(zend_uchar, type)
993#endif
994    IFRESTORE(`COPY(key)', `
995        PROC_ZSTRING_L(type, key, key_len)
996    ')
[506]997    DISPATCH(ulong, h)
[268]998')
999dnl }}}
1000#endif
[496]1001#ifdef E_STRICT
1002DEF_STRUCT_P_FUNC(`xc_compilererror_t', , `dnl {{{
[648]1003    DISPATCH(int, type)
[496]1004    DISPATCH(uint, lineno)
1005    DISPATCH(int, error_len)
1006    PROC_STRING_L(error, error_len)
1007')
1008dnl }}}
1009#endif
[1]1010DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
[311]1011    IFCOPY(`
1012        processor->php_dst = dst;
1013        processor->php_src = src;
1014    ')
1015
1016    DISPATCH(xc_hash_value_t, hvalue)
1017    /* skip */
1018    DONE(next)
1019    COPY(cache)
1020    DISPATCH(xc_md5sum_t, md5)
1021    DISPATCH(zend_ulong, refcount)
1022
[1]1023    DISPATCH(size_t, sourcesize)
[311]1024    DISPATCH(zend_ulong, hits)
1025    DISPATCH(size_t, size)
[1]1026
[662]1027    IFRESTORE(`COPY(op_array_info)', `
1028        STRUCT(xc_op_array_info_t, op_array_info)
1029    ')
1030    IFRESTORE(`
1031        processor->active_op_array_infos_src = &dst->op_array_info;
1032        processor->active_op_array_index = 0;
1033    ')
[1]1034    STRUCT_P(zend_op_array, op_array)
1035
[95]1036#ifdef HAVE_XCACHE_CONSTANT
1037    DISPATCH(zend_uint, constinfo_cnt)
[503]1038    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
[95]1039#endif
1040
[1]1041    DISPATCH(zend_uint, funcinfo_cnt)
1042    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
1043
1044    DISPATCH(zend_uint, classinfo_cnt)
[662]1045    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos, , IFRESTORE(`processor->active_class_index'))
[268]1046#ifdef ZEND_ENGINE_2_1
1047    DISPATCH(zend_uint, autoglobal_cnt)
[495]1048    IFRESTORE(`
1049        COPY(autoglobals)
1050    ', `
1051        STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
1052    ')
[268]1053#endif
[496]1054#ifdef E_STRICT
1055    DISPATCH(zend_uint, compilererror_cnt)
1056    IFRESTORE(`
1057        COPY(compilererrors)
1058    ', `
1059        STRUCT_ARRAY(compilererror_cnt, xc_compilererror_t, compilererrors)
1060    ')
1061#endif
[548]1062#ifndef ZEND_COMPILE_DELAYED_BINDING
[212]1063    DISPATCH(zend_bool, have_early_binding)
[548]1064#endif
[311]1065    DISPATCH(zend_bool, have_references)
[1]1066')
1067dnl }}}
1068DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
[230]1069    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
[4]1070    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
[311]1071    DISPATCH(zend_bool, have_references)
[1]1072    DONE(value)
1073')
1074dnl }}}
1075dnl {{{ xc_entry_t
1076DEF_STRUCT_P_FUNC(`xc_entry_t', , `
1077    DISPATCH(xc_entry_type_t, type)
1078    DISPATCH(size_t, size)
1079
1080    DISPATCH(xc_hash_value_t, hvalue)
1081    COPY(cache)
1082    /* skip */
1083    DONE(next)
1084
1085    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
1086
1087    DISPATCH(time_t, ctime)
1088    DISPATCH(time_t, atime)
1089    DISPATCH(time_t, dtime)
[114]1090    DISPATCH(long, ttl)
[1]1091    DISPATCH(zend_ulong, hits)
1092#ifdef IS_UNICODE
1093    DISPATCH(zend_uchar, name_type)
1094#endif
1095    dnl {{{ name
1096    DISABLECHECK(`
1097#ifdef IS_UNICODE
1098        if (src->name_type == IS_UNICODE) {
1099            DISPATCH(int32_t, name.ustr.len)
1100        }
1101        else {
1102            DISPATCH(int, name.str.len)
1103        }
1104#else
1105        DISPATCH(int, name.str.len)
1106#endif
[103]1107        IFRESTORE(`COPY(name.str.val)', `
1108#ifdef IS_UNICODE
1109            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
1110#else
1111            PROC_STRING_L(name.str.val, name.str.len)
1112#endif
1113        ')
[1]1114    ')
1115    DONE(name)
1116    dnl }}}
1117
1118    dnl {{{ data
1119    DISABLECHECK(`
1120        switch (src->type) {
1121        case XC_TYPE_PHP:
[662]1122            IFCALCCOPY(`COPY(data.php)', `STRUCT_P(xc_entry_data_php_t, data.php)')
[1]1123            break;
[311]1124
[1]1125        case XC_TYPE_VAR:
1126            STRUCT_P(xc_entry_data_var_t, data.var)
1127            break;
[311]1128
[1]1129        default:
1130            assert(0);
1131        }
1132    ')
1133    DONE(data)
1134    dnl }}}
[311]1135    DISPATCH(time_t, mtime)
1136#ifdef HAVE_INODE
1137    DISPATCH(int, device)
1138    DISPATCH(int, inode)
1139#endif
[684]1140
[688]1141    if (src->type == XC_TYPE_PHP) {
1142        DISPATCH(int, filepath_len)
1143        IFRESTORE(`COPY(filepath)', `PROC_STRING_L(filepath, filepath_len)')
1144        DISPATCH(int, dirpath_len)
1145        IFRESTORE(`COPY(dirpath)', `PROC_STRING_L(dirpath, dirpath_len)')
[684]1146#ifdef IS_UNICODE
[688]1147        DISPATCH(int, ufilepath_len)
1148        IFRESTORE(`COPY(ufilepath)', `PROC_USTRING_L(ufilepath, ufilepath_len)')
1149        DISPATCH(int, udirpath_len)
1150        IFRESTORE(`COPY(udirpath)', `PROC_USTRING_L(udirpath, udirpath_len)')
[684]1151#endif
[688]1152    }
1153    else {
1154        DONE(filepath_len)
1155        DONE(filepath)
1156        DONE(dirpath_len)
1157        DONE(dirpath)
1158#ifdef IS_UNICODE
1159        DONE(ufilepath_len)
1160        DONE(ufilepath)
1161        DONE(udirpath_len)
1162        DONE(udirpath)
1163#endif
1164    }
[1]1165')
1166dnl }}}
1167dnl ====================================================
Note: See TracBrowser for help on using the repository browser.