source: trunk/processor/processor.m4 @ 822

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

initial PHP_5_4 support

  • Property svn:eol-style set to native
File size: 28.8 KB
Line 
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')
7#ifdef HAVE_XCACHE_CONSTANT
8DECL_STRUCT_P_FUNC(`zend_constant')
9#endif
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)
21    PROC_ZSTRING_L(, name, name_len)
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', , `
58#ifdef ZEND_ENGINE_2_2
59    DISPATCH(int, start)
60#endif
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);
76        Z_SET_REFCOUNT(*dst, 1);
77        DONE(value)
78        DONE(type)
79#ifdef ZEND_ENGINE_2_3
80        DONE(is_ref__gc)
81        DONE(refcount__gc)
82#else
83        DONE(is_ref)
84        DONE(refcount)
85#endif
86    } while(0);
87    ', `
88        dnl IFDASM else
89        /* Variable information */
90dnl {{{ zvalue_value
91        DISABLECHECK(`
92        switch ((Z_TYPE_P(src) & IS_CONSTANT_TYPE_MASK)) {
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:
121                DISPATCH(int32_t, value.uni.len)
122                PROC_ZSTRING_L(1, value.uni.val, value.uni.len)
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)
147#ifdef ZEND_ENGINE_2_3
148        DISPATCH(zend_uchar, is_ref__gc)
149#else
150        DISPATCH(zend_uchar, is_ref)
151#endif
152
153#ifdef ZEND_ENGINE_2_3
154        DISPATCH(zend_uint, refcount__gc)
155#elif defined(ZEND_ENGINE_2)
156        DISPATCH(zend_uint, refcount)
157#else
158        DISPATCH(zend_ushort, refcount)
159#endif
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;
173                    if (zend_hash_find(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void **) &ppzv) == SUCCESS) {
174                        IFCOPY(`
175                            dst[0] = *ppzv;
176                            /* *dst is updated */
177                            dnl fprintf(stderr, "*dst is set to %p, KIND is_shm %d\n", dst[0], xc_is_shm(dst[0]));
178                        ')
179                        IFCALCSTORE(`processor->have_references = 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];
195                        FIXPOINTER_EX(zval, pzv)
196                    ')
197                    if (zend_hash_add(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void *) &pzv, sizeof(pzv), NULL) == SUCCESS) {
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            ')
209            IFDPRINT(`INDENT()`'fprintf(stderr, "[%p] ", src[0]);')
210            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
211            FIXPOINTER_EX(zval, dst[0])
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)
221    PROC_ZSTRING_L(, name, name_len)
222    DISPATCH(zend_uint, class_name_len)
223    PROC_ZSTRING_L(, class_name, class_name_len)
224#ifdef ZEND_ENGINE_2_4
225    DISPATCH(zend_uchar, type_hint)
226#else
227    DISPATCH(zend_bool, array_type_hint)
228#endif
229    DISPATCH(zend_bool, allow_null)
230    DISPATCH(zend_bool, pass_by_reference)
231#ifndef ZEND_ENGINE_2_4
232    DISPATCH(zend_bool, return_reference)
233    DISPATCH(int, required_num_args)
234#endif
235')
236#endif
237dnl }}}
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)
243    pushdef(`emalloc', `malloc($1)')
244    pushdef(`ecalloc', `calloc($1, $2)')
245    PROC_ZSTRING_N(, name, name_len)
246    popdef(`ecalloc')
247    popdef(`emalloc')
248    DISPATCH(int, module_number)
249')
250dnl }}}
251#endif
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)
278    PROC_ZSTRING_L(, name, name_length)
279    DISPATCH(ulong, h)
280#ifdef ZEND_ENGINE_2_4
281    DISPATCH(int, offset)
282#endif
283#ifdef ZEND_ENGINE_2_1
284    DISPATCH(int, doc_comment_len)
285    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
286#endif
287    dnl isnt in php6 yet
288#if defined(ZEND_ENGINE_2_2)
289    PROC_CLASS_ENTRY_P(ce)
290#endif
291')
292#endif
293dnl }}}
294DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
295    IFCALCCOPY(`
296        processor->active_class_entry_src = src;
297        IFCOPY(`processor->active_class_entry_dst = dst;')
298    ')
299    DISPATCH(char, type)
300    DISPATCH(zend_uint, name_length)
301    PROC_ZSTRING_L(, name, name_length)
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
317#ifndef ZEND_ENGINE_2_4
318    DISPATCH(zend_bool, constants_updated)
319#endif
320#ifdef ZEND_ENGINE_2
321    DISPATCH(zend_uint, ce_flags)
322#endif
323
324#ifdef ZEND_ENGINE_2
325    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
326#endif
327
328#ifdef ZEND_ENGINE_2_4
329    DISPATCH(int, default_properties_count)
330    STRUCT_ARRAY(default_properties_count, zval_ptr, default_properties_table)
331    DISPATCH(int, default_static_members_count)
332    STRUCT_ARRAY(default_static_members_count, zval_ptr, default_static_members_table)
333    IFCOPY(`dst->static_members_table = dst->default_static_members_table;')
334    DONE(static_members_table)
335#else
336    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
337    DONE(builtin_functions)
338    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
339#   ifdef ZEND_ENGINE_2_1
340    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
341    IFCOPY(`dst->static_members = &dst->default_static_members;')
342    DONE(static_members)
343#   elif defined(ZEND_ENGINE_2)
344    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
345#   endif
346#endif /* ZEND_ENGINE_2_4 */
347
348#ifdef ZEND_ENGINE_2
349    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
350
351    dnl runtime binding: ADD_INTERFACE will deal with it
352    dnl runtime binding: ADD_TRAIT will deal with it
353    IFRESTORE(`
354        if (src->num_interfaces) {
355            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
356            DONE(`interfaces')
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
363        }
364        else {
365            COPYNULL(`interfaces')
366#   ifdef ZEND_ENGINE_2_4
367            COPYNULL(`traits')
368            COPYNULL(`trait_aliases')
369            COPYNULL(`trait_precedences')
370#   endif
371        }
372    ')
373    IFDASM(`
374        if (src->num_interfaces) {
375            /*
376            int i;
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            */
387            DONE(`interfaces')
388#   ifdef ZEND_ENGINE_2_4
389            DONE(`traits')
390            DONE(`trait_aliases')
391            DONE(`trait_precedences')
392#   endif
393        }
394        else {
395            COPYNULL(`interfaces')
396#   ifdef ZEND_ENGINE_2_4
397            COPYNULL(`traits')
398            COPYNULL(`trait_aliases')
399            COPYNULL(`trait_precedences')
400#   endif
401        }
402    ')
403    IFRESTORE(`', `
404        IFDASM(`', `
405            DONE(`interfaces')
406#   ifdef ZEND_ENGINE_2_4
407            DONE(`traits')
408            DONE(`trait_aliases')
409            DONE(`trait_precedences')
410#   endif
411        ')
412    ')
413    DISPATCH(zend_uint, num_interfaces)
414#   ifdef ZEND_ENGINE_2_4
415    DISPATCH(zend_uint, num_traits)
416#   endif
417
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
428    IFRESTORE(`dst->filename = processor->entry_src->filepath;DONE(filename)', `PROC_STRING(filename)')
429    DISPATCH(zend_uint, line_start)
430    DISPATCH(zend_uint, line_end)
431#       ifdef ZEND_ENGINE_2_1
432    DISPATCH(zend_uint, doc_comment_len)
433    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
434#       endif
435#   endif
436
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)
444#   ifdef ZEND_ENGINE_2_3
445    COPY(get_static_method)
446#   endif
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 */
456#   ifdef ZEND_ENGINE_2_1
457    COPY(__unset)
458    COPY(__isset)
459#    if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
460    COPY(__tostring)
461#    endif
462#   endif
463    COPY(__call)
464#   ifdef ZEND_CALLSTATIC_FUNC_NAME
465    COPY(__callstatic)
466#   endif
467#   ifndef ZEND_ENGINE_2_4
468    /* # NOT DONE */
469    COPY(module)
470#   endif
471#else /* ZEND_ENGINE_2 */
472    COPY(handle_function_call)
473    COPY(handle_property_get)
474    COPY(handle_property_set)
475#endif
476    dnl must do after SETNULL(constructor) and dst->parent
477    STRUCT(HashTable, function_table, HashTable_zend_function)
478    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
479    IFCALCCOPY(`
480        processor->active_class_entry_src = NULL;
481        IFCOPY(`processor->active_class_entry_dst = NULL;')
482    ')
483')
484dnl }}}
485#ifdef ZEND_ENGINE_2_4
486undefine(`UNION_znode_op')
487define(`UNION_znode_op', `dnl {{{
488#ifndef NDEBUG
489    switch ((src->$1_type ifelse($1, `result', & ~EXT_TYPE_UNUSED))) {
490    case IS_CONST:
491    case IS_VAR:
492    case IS_CV:
493    case IS_TMP_VAR:
494    case IS_UNUSED:
495        break;
496
497    default:
498        assert(0);
499    }
500#endif
501
502    dnl dirty dispatch
503    DISABLECHECK(`
504    switch ((src->$1_type ifelse($1, `result', & ~EXT_TYPE_UNUSED))) {
505        case IS_CONST:
506            ifelse($1, `result', `
507                DISPATCH(zend_uint, $1.constant)
508            ', `
509                IFDASM(`{
510                    zval *zv;
511                    ALLOC_INIT_ZVAL(zv);
512                    *zv = src->$1.literal->constant;
513                    zval_copy_ctor(zv);
514                    add_assoc_zval_ex(dst, ZEND_STRS("$1.constant"), zv);
515                }
516                ', `
517                    IFCOPY(`
518                        dst->$1 = src->$1;
519                    ', `
520                        DISPATCH(zend_uint, $1.constant)
521                    ')
522                ')
523            ')
524            break;
525        IFCOPY(`
526            IFNOTMEMCPY(`
527                default:
528                    $1 = $2;
529            ')
530        ', `
531        case IS_VAR:
532        case IS_TMP_VAR:
533        case IS_CV:
534            DISPATCH(zend_uint, $1.var)
535            break;
536        case IS_UNUSED:
537            IFDASM(`DISPATCH(zend_uint, $1.var)')
538            DISPATCH(zend_uint, $1.opline_num)
539            break;
540        ')
541    }
542    ')
543    DONE($1)
544')
545dnl }}}
546#else
547DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
548    DISPATCH(int, op_type)
549
550#ifdef IS_CV
551#   define XCACHE_IS_CV IS_CV
552#else
553/* compatible with zend optimizer */
554#   define XCACHE_IS_CV 16
555#endif
556    assert(src->op_type == IS_CONST ||
557        src->op_type == IS_VAR ||
558        src->op_type == XCACHE_IS_CV ||
559        src->op_type == IS_TMP_VAR ||
560        src->op_type == IS_UNUSED);
561    dnl dirty dispatch
562    DISABLECHECK(`
563    switch (src->op_type) {
564        case IS_CONST:
565            STRUCT(zval, u.constant)
566            break;
567        IFCOPY(`
568            IFNOTMEMCPY(`
569                default:
570                    memcpy(&dst->u, &src->u, sizeof(src->u));
571            ')
572        ', `
573        case IS_VAR:
574        case IS_TMP_VAR:
575        case XCACHE_IS_CV:
576            DISPATCH(zend_uint, u.var)
577            DISPATCH(zend_uint, u.EA.type)
578            break;
579        case IS_UNUSED:
580            IFDASM(`DISPATCH(zend_uint, u.var)')
581            DISPATCH(zend_uint, u.opline_num)
582#ifndef ZEND_ENGINE_2
583            DISPATCH(zend_uint, u.fetch_type)
584#endif
585            DISPATCH(zend_uint, u.EA.type)
586            break;
587        ')
588    }
589    ')
590    DONE(u)
591#if 0
592    DONE(EA)
593#endif
594#undef XCACHE_IS_CV
595')
596dnl }}}
597#endif
598DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
599    DISPATCH(zend_uchar, opcode)
600#ifdef ZEND_ENGINE_2_4
601    UNION_znode_op(result)
602    UNION_znode_op(op1)
603    UNION_znode_op(op2)
604#else
605    STRUCT(znode, result)
606    STRUCT(znode, op1)
607    STRUCT(znode, op2)
608#endif
609    DISPATCH(ulong, extended_value)
610    DISPATCH(uint, lineno)
611#ifdef ZEND_ENGINE_2_1
612#ifdef ZEND_ENGINE_2_4
613    DISPATCH(zend_uchar, op1_type)
614    DISPATCH(zend_uchar, op2_type)
615    DISPATCH(zend_uchar, result_type)
616#endif
617    IFCOPY(`
618        pushdef(`UNION_znode_op_literal', `
619            if (dst->$1_type == IS_CONST) {
620                IFSTORE(`
621                    dst->$1.constant = src->$1.literal - processor->active_op_array_src->literals;
622                    dst->$1.literal = &processor->active_op_array_dst->literals[dst->$1.constant];
623                ')
624            }
625        ')
626        UNION_znode_op_literal(op1)
627        UNION_znode_op_literal(op2)
628        popdef(`UNION_znode_op_literal')
629        switch (src->opcode) {
630#ifdef ZEND_GOTO
631            case ZEND_GOTO:
632#endif
633            case ZEND_JMP:
634                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);
635                Z_OP(dst->op1).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op1).jmp_addr - processor->active_opcodes_src);
636                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);
637                break;
638
639            case ZEND_JMPZ:
640            case ZEND_JMPNZ:
641            case ZEND_JMPZ_EX:
642            case ZEND_JMPNZ_EX:
643#ifdef ZEND_JMP_SET
644            case ZEND_JMP_SET:
645#endif
646                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);
647                Z_OP(dst->op2).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op2).jmp_addr - processor->active_opcodes_src);
648                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);
649                break;
650
651            default:
652                break;
653        }
654    ')
655    DISPATCH(opcode_handler_t, handler)
656#endif
657')
658dnl }}}
659#ifdef ZEND_ENGINE_2_4
660DEF_STRUCT_P_FUNC(`zend_literal', , `dnl {{{
661    STRUCT(zval, constant)
662    DISPATCH(zend_ulong, hash_value)
663    DISPATCH(zend_uint,  cache_slot)
664')
665dnl }}}
666#endif
667DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
668    IFRESTORE(`
669    const xc_op_array_info_t *op_array_info = &processor->active_op_array_infos_src[processor->active_op_array_index++];
670    dnl shadow copy must NOT meet:
671    dnl readonly_protection=on
672    dnl main op_array && have early binding
673#ifdef ZEND_COMPILE_DELAYED_BINDING
674    zend_bool need_early_binding = 0;
675#else
676    zend_bool need_early_binding = processor->php_src->have_early_binding;
677#endif
678    zend_bool shallow_copy = !processor->readonly_protection && !(src == processor->php_src->op_array && need_early_binding);
679    if (shallow_copy) {
680        zend_bool gc_arg_info = 0;
681        zend_bool gc_opcodes  = 0;
682        /* really fast shallow copy */
683        memcpy(dst, src, sizeof(src[0]));
684        dst->refcount[0] = 1000;
685        /* deep */
686        STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
687#ifdef ZEND_ENGINE_2
688        STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
689        gc_arg_info = 1;
690#endif
691        dst->filename = processor->entry_src->filepath;
692#ifdef ZEND_ENGINE_2_4
693        if (src->literals /* || op_array_info->literalsinfo_cnt */) {
694            gc_opcodes = 1;
695        }
696#else
697        if (op_array_info->oplineinfo_cnt) {
698            gc_opcodes = 1;
699        }
700#endif
701        if (gc_opcodes) {
702            zend_op *opline, *end;
703            COPY_N_EX(last, zend_op, opcodes)
704
705            for (opline = dst->opcodes, end = opline + src->last; opline < end; ++opline) {
706#ifdef ZEND_ENGINE_2_4
707                pushdef(`UNION_znode_op_literal', `
708                    if (opline->$1_type == IS_CONST) {
709                        opline->$1.constant = opline->$1.literal - src->literals;
710                        opline->$1.literal = &dst->literals[opline->$1.constant];
711                    }
712                ')
713                UNION_znode_op_literal(op1)
714                UNION_znode_op_literal(op2)
715                popdef(`UNION_znode_op_literal')
716#endif
717
718                switch (opline->opcode) {
719#ifdef ZEND_GOTO
720                    case ZEND_GOTO:
721#endif
722                    case ZEND_JMP:
723                        Z_OP(opline->op1).jmp_addr = dst->opcodes + (Z_OP(opline->op1).jmp_addr - src->opcodes);
724                        break;
725
726                    case ZEND_JMPZ:
727                    case ZEND_JMPNZ:
728                    case ZEND_JMPZ_EX:
729                    case ZEND_JMPNZ_EX:
730#ifdef ZEND_JMP_SET
731                    case ZEND_JMP_SET:
732#endif
733                        Z_OP(opline->op2).jmp_addr = dst->opcodes + (Z_OP(opline->op2).jmp_addr - src->opcodes);
734                        break;
735
736                    default:
737                        break;
738                }
739            }
740        }
741        if (gc_arg_info || gc_opcodes) {
742            xc_gc_op_array_t gc_op_array;
743#ifdef ZEND_ENGINE_2
744            gc_op_array.num_args = gc_arg_info ? dst->num_args : 0;
745            gc_op_array.arg_info = gc_arg_info ? dst->arg_info : NULL;
746#endif
747            gc_op_array.opcodes  = gc_opcodes ? dst->opcodes : NULL;
748            xc_gc_add_op_array(&gc_op_array TSRMLS_CC);
749        }
750        define(`SKIPASSERT_ONCE')
751    }
752    else
753    ')
754    do {
755    dnl RESTORE is done above!
756
757    /* Common elements */
758    DISPATCH(zend_uchar, type)
759    PROC_ZSTRING(, function_name)
760#ifdef ZEND_ENGINE_2
761    DISPATCH(zend_uint, fn_flags)
762    STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
763    DISPATCH(zend_uint, num_args)
764    DISPATCH(zend_uint, required_num_args)
765#   ifndef ZEND_ENGINE_2_4
766    DISPATCH(zend_bool, pass_rest_by_reference)
767#   endif
768#else
769    if (src->arg_types) {
770        ALLOC(dst->arg_types, zend_uchar, src->arg_types[0] + 1)
771        IFCOPY(`memcpy(dst->arg_types, src->arg_types, sizeof(src->arg_types[0]) * (src->arg_types[0]+1));')
772        IFDASM(`do {
773            int i;
774            zval *zv;
775            ALLOC_INIT_ZVAL(zv);
776            array_init(zv);
777            for (i = 0; i < src->arg_types[0]; i ++) {
778                add_next_index_long(zv, src->arg_types[i + 1]);
779            }
780            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
781        } while (0);')
782        DONE(arg_types)
783    }
784    else {
785        IFDASM(`do {
786            /* empty array */
787            zval *zv;
788            ALLOC_INIT_ZVAL(zv);
789            array_init(zv);
790            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
791        } while (0);
792        DONE(arg_types)
793        ', `
794        COPYNULL(arg_types)
795        ')
796    }
797#endif
798#ifndef ZEND_ENGINE_2_4
799    DISPATCH(unsigned char, return_reference)
800#endif
801    /* END of common elements */
802#ifdef IS_UNICODE
803    dnl SETNULL(u_twin)
804#endif
805
806    STRUCT_P(zend_uint, refcount)
807    UNFIXPOINTER(zend_uint, refcount)
808    IFSTORE(`dst->refcount[0] = 1;')
809
810#ifdef ZEND_ENGINE_2_4
811    dnl before copying opcodes
812    DISPATCH(int, last_literal)
813    STRUCT_ARRAY(last_literal, zend_literal, literals)
814#endif
815
816    pushdef(`AFTER_ALLOC', `IFCOPY(`
817#ifndef NDEBUG
818        processor->active_op_array_dst = dst;
819        processor->active_op_array_src = src;
820#endif
821        processor->active_opcodes_dst = dst->opcodes;
822        processor->active_opcodes_src = src->opcodes;
823    ')')
824    STRUCT_ARRAY(last, zend_op, opcodes)
825    popdef(`AFTER_ALLOC')
826    DISPATCH(zend_uint, last)
827#ifndef ZEND_ENGINE_2_4
828    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
829#endif
830
831#ifdef IS_CV
832    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
833    DISPATCH(int, last_var)
834#   ifndef ZEND_ENGINE_2_4
835    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
836#   endif
837#else
838    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
839    IFDASM(`
840        sinclude(srcdir`/processor/zend_cv.m4')
841        ')
842#endif
843
844    DISPATCH(zend_uint, T)
845
846    STRUCT_ARRAY(last_brk_cont, zend_brk_cont_element, brk_cont_array)
847    DISPATCH(zend_uint, last_brk_cont)
848#ifndef ZEND_ENGINE_2_4
849    DISPATCH(zend_uint, current_brk_cont)
850#endif
851#ifndef ZEND_ENGINE_2
852    DISPATCH(zend_bool, uses_globals)
853#endif
854
855#ifdef ZEND_ENGINE_2
856    STRUCT_ARRAY(last_try_catch, zend_try_catch_element, try_catch_array)
857    DISPATCH(int, last_try_catch)
858#endif
859
860    STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
861
862#ifndef ZEND_ENGINE_2_4
863    COPY(start_op)
864    DISPATCH(int, backpatch_count)
865#endif
866#ifdef ZEND_ENGINE_2_3
867    DISPATCH(zend_uint, this_var)
868#endif
869
870#ifndef ZEND_ENGINE_2_4
871    DISPATCH(zend_bool, done_pass_two)
872#endif
873    /* 5.0 <= ver < 5.3 */
874#if defined(ZEND_ENGINE_2) && !defined(ZEND_ENGINE_2_3)
875    DISPATCH(zend_bool, uses_this)
876#endif
877
878    IFRESTORE(`dst->filename = processor->entry_src->filepath;DONE(filename)', `PROC_STRING(filename)')
879#ifdef IS_UNICODE
880    IFRESTORE(`
881        COPY(script_encoding)
882    ', `
883        PROC_STRING(script_encoding)
884    ')
885#endif
886#ifdef ZEND_ENGINE_2
887    DISPATCH(zend_uint, line_start)
888    DISPATCH(zend_uint, line_end)
889    DISPATCH(int, doc_comment_len)
890    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
891#endif
892#ifdef ZEND_COMPILE_DELAYED_BINDING
893    DISPATCH(zend_uint, early_binding);
894#endif
895
896    /* reserved */
897    DONE(reserved)
898#if defined(HARDENING_PATCH) && HARDENING_PATCH
899    DISPATCH(zend_bool, created_by_eval)
900#endif
901#ifdef ZEND_ENGINE_2_4
902    COPYNULL(run_time_cache)
903    COPYNULL(last_cache_slot)
904#endif
905    } while (0);
906    IFRESTORE(`xc_fix_op_array_info(processor->entry_src, processor->php_src, dst, !shallow_copy, op_array_info TSRMLS_CC);')
907
908#ifdef ZEND_ENGINE_2
909    dnl mark it as -1 on store, and lookup parent on restore
910    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
911            IFRESTORE(`do {
912                zend_function *parent;
913                if (src->prototype != NULL
914                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
915                        UG(unicode) ? IS_UNICODE : IS_STRING,
916                        src->function_name, xc_zstrlen(UG(unicode) ? IS_UNICODE : IS_STRING, src->function_name) + 1,
917                        (void **) &parent) == SUCCESS) {
918                    /* see do_inherit_method_check() */
919                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
920                      dst->prototype = parent;
921                    } else if (!(parent->common.fn_flags & ZEND_ACC_CTOR) || (parent->common.prototype && (parent->common.prototype->common.scope->ce_flags & ZEND_ACC_INTERFACE))) {
922                        /* ctors only have a prototype if it comes from an interface */
923                        dst->prototype = parent->common.prototype ? parent->common.prototype : parent;
924                    }
925                    else {
926                        dst->prototype = NULL;
927                    }
928                }
929                else {
930                    dst->prototype = NULL;
931                }
932                DONE(prototype)
933            } while (0);
934            ', `
935                COPYNULL(prototype)
936            ')
937    ')
938
939#endif
940
941#ifdef ZEND_ENGINE_2
942    PROC_CLASS_ENTRY_P(scope)
943    IFCOPY(`
944        if (src->scope) {
945            xc_fix_method(processor, dst TSRMLS_CC);
946        }
947    ')
948#endif
949
950    IFRESTORE(`
951        if (xc_have_op_array_ctor) {
952            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
953        }
954    ')
955')
956dnl }}}
957
958#ifdef HAVE_XCACHE_CONSTANT
959DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
960    DISPATCH(zend_uint, key_size)
961#ifdef IS_UNICODE
962    DISPATCH(zend_uchar, type)
963#endif
964    IFRESTORE(`COPY(key)', `
965        PROC_ZSTRING_N(type, key, key_size)
966    ')
967    DISPATCH(ulong, h)
968    STRUCT(zend_constant, constant)
969')
970dnl }}}
971#endif
972DEF_STRUCT_P_FUNC(`xc_op_array_info_t', , `dnl {{{
973#ifdef ZEND_ENGINE_2_4
974    DISPATCH(zend_uint, literalinfo_cnt)
975    DISPATCH_ARRAY(literalinfo_cnt, int, literalinfos)
976#else
977    DISPATCH(zend_uint, oplineinfo_cnt)
978    DISPATCH_ARRAY(oplineinfo_cnt, int, oplineinfos)
979#endif
980')
981dnl }}}
982DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
983    DISPATCH(zend_uint, key_size)
984#ifdef IS_UNICODE
985    DISPATCH(zend_uchar, type)
986#endif
987    IFRESTORE(`COPY(key)', `
988        PROC_ZSTRING_N(type, key, key_size)
989    ')
990    DISPATCH(ulong, h)
991    IFRESTORE(`COPY(op_array_info)', `
992        STRUCT(xc_op_array_info_t, op_array_info)
993    ')
994    IFRESTORE(`
995        processor->active_op_array_infos_src = &src->op_array_info;
996        processor->active_op_array_index = 0;
997    ')
998    STRUCT(zend_function, func)
999')
1000dnl }}}
1001DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
1002    DISPATCH(zend_uint, key_size)
1003#ifdef IS_UNICODE
1004    DISPATCH(zend_uchar, type)
1005#endif
1006    IFRESTORE(`COPY(key)', `
1007        PROC_ZSTRING_N(type, key, key_size)
1008    ')
1009    DISPATCH(ulong, h)
1010    DISPATCH(zend_uint, methodinfo_cnt)
1011    IFRESTORE(`COPY(methodinfos)', `
1012        STRUCT_ARRAY(methodinfo_cnt, xc_op_array_info_t, methodinfos)
1013    ')
1014    IFRESTORE(`
1015        processor->active_op_array_infos_src = src->methodinfos;
1016        processor->active_op_array_index = 0;
1017    ')
1018#ifdef ZEND_ENGINE_2
1019    STRUCT_P(zend_class_entry, cest)
1020#else
1021    STRUCT(zend_class_entry, cest)
1022#endif
1023#ifndef ZEND_COMPILE_DELAYED_BINDING
1024    DISPATCH(int, oplineno)
1025#endif
1026')
1027dnl }}}
1028#ifdef ZEND_ENGINE_2_1
1029DEF_STRUCT_P_FUNC(`xc_autoglobal_t', , `dnl {{{
1030    DISPATCH(zend_uint, key_len)
1031#ifdef IS_UNICODE
1032    DISPATCH(zend_uchar, type)
1033#endif
1034    IFRESTORE(`COPY(key)', `
1035        PROC_ZSTRING_L(type, key, key_len)
1036    ')
1037    DISPATCH(ulong, h)
1038')
1039dnl }}}
1040#endif
1041#ifdef E_STRICT
1042DEF_STRUCT_P_FUNC(`xc_compilererror_t', , `dnl {{{
1043    DISPATCH(int, type)
1044    DISPATCH(uint, lineno)
1045    DISPATCH(int, error_len)
1046    PROC_STRING_L(error, error_len)
1047')
1048dnl }}}
1049#endif
1050DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
1051    IFCOPY(`
1052        processor->php_dst = dst;
1053        processor->php_src = src;
1054    ')
1055
1056    DISPATCH(xc_hash_value_t, hvalue)
1057    /* skip */
1058    DONE(next)
1059    COPY(cache)
1060    DISPATCH(xc_md5sum_t, md5)
1061    DISPATCH(zend_ulong, refcount)
1062
1063    DISPATCH(size_t, sourcesize)
1064    DISPATCH(zend_ulong, hits)
1065    DISPATCH(size_t, size)
1066
1067    IFRESTORE(`COPY(op_array_info)', `
1068        STRUCT(xc_op_array_info_t, op_array_info)
1069    ')
1070    IFRESTORE(`
1071        processor->active_op_array_infos_src = &dst->op_array_info;
1072        processor->active_op_array_index = 0;
1073    ')
1074    STRUCT_P(zend_op_array, op_array)
1075
1076#ifdef HAVE_XCACHE_CONSTANT
1077    DISPATCH(zend_uint, constinfo_cnt)
1078    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
1079#endif
1080
1081    DISPATCH(zend_uint, funcinfo_cnt)
1082    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
1083
1084    DISPATCH(zend_uint, classinfo_cnt)
1085    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos, , IFRESTORE(`processor->active_class_index'))
1086#ifdef ZEND_ENGINE_2_1
1087    DISPATCH(zend_uint, autoglobal_cnt)
1088    IFRESTORE(`
1089        COPY(autoglobals)
1090    ', `
1091        STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
1092    ')
1093#endif
1094#ifdef E_STRICT
1095    DISPATCH(zend_uint, compilererror_cnt)
1096    IFRESTORE(`
1097        COPY(compilererrors)
1098    ', `
1099        STRUCT_ARRAY(compilererror_cnt, xc_compilererror_t, compilererrors)
1100    ')
1101#endif
1102#ifndef ZEND_COMPILE_DELAYED_BINDING
1103    DISPATCH(zend_bool, have_early_binding)
1104#endif
1105    DISPATCH(zend_bool, have_references)
1106')
1107dnl }}}
1108DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
1109    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
1110    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
1111    DISPATCH(zend_bool, have_references)
1112    DONE(value)
1113')
1114dnl }}}
1115dnl {{{ xc_entry_t
1116DEF_STRUCT_P_FUNC(`xc_entry_t', , `
1117    DISPATCH(xc_entry_type_t, type)
1118    DISPATCH(size_t, size)
1119
1120    DISPATCH(xc_hash_value_t, hvalue)
1121    COPY(cache)
1122    /* skip */
1123    DONE(next)
1124
1125    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
1126
1127    DISPATCH(time_t, ctime)
1128    DISPATCH(time_t, atime)
1129    DISPATCH(time_t, dtime)
1130    DISPATCH(long, ttl)
1131    DISPATCH(zend_ulong, hits)
1132#ifdef IS_UNICODE
1133    DISPATCH(zend_uchar, name_type)
1134#endif
1135    dnl {{{ name
1136    DISABLECHECK(`
1137#ifdef IS_UNICODE
1138        if (src->name_type == IS_UNICODE) {
1139            DISPATCH(int32_t, name.ustr.len)
1140        }
1141        else {
1142            DISPATCH(int, name.str.len)
1143        }
1144#else
1145        DISPATCH(int, name.str.len)
1146#endif
1147        IFRESTORE(`COPY(name.str.val)', `
1148#ifdef IS_UNICODE
1149            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
1150#else
1151            PROC_STRING_L(name.str.val, name.str.len)
1152#endif
1153        ')
1154    ')
1155    DONE(name)
1156    dnl }}}
1157
1158    dnl {{{ data
1159    DISABLECHECK(`
1160        switch (src->type) {
1161        case XC_TYPE_PHP:
1162            IFCALCCOPY(`COPY(data.php)', `STRUCT_P(xc_entry_data_php_t, data.php)')
1163            break;
1164
1165        case XC_TYPE_VAR:
1166            STRUCT_P(xc_entry_data_var_t, data.var)
1167            break;
1168
1169        default:
1170            assert(0);
1171        }
1172    ')
1173    DONE(data)
1174    dnl }}}
1175    DISPATCH(time_t, mtime)
1176#ifdef HAVE_INODE
1177    DISPATCH(int, device)
1178    DISPATCH(int, inode)
1179#endif
1180
1181    if (src->type == XC_TYPE_PHP) {
1182        DISPATCH(int, filepath_len)
1183        IFRESTORE(`COPY(filepath)', `PROC_STRING_L(filepath, filepath_len)')
1184        DISPATCH(int, dirpath_len)
1185        IFRESTORE(`COPY(dirpath)', `PROC_STRING_L(dirpath, dirpath_len)')
1186#ifdef IS_UNICODE
1187        DISPATCH(int, ufilepath_len)
1188        IFRESTORE(`COPY(ufilepath)', `PROC_USTRING_L(ufilepath, ufilepath_len)')
1189        DISPATCH(int, udirpath_len)
1190        IFRESTORE(`COPY(udirpath)', `PROC_USTRING_L(udirpath, udirpath_len)')
1191#endif
1192    }
1193    else {
1194        DONE(filepath_len)
1195        DONE(filepath)
1196        DONE(dirpath_len)
1197        DONE(dirpath)
1198#ifdef IS_UNICODE
1199        DONE(ufilepath_len)
1200        DONE(ufilepath)
1201        DONE(udirpath_len)
1202        DONE(udirpath)
1203#endif
1204    }
1205')
1206dnl }}}
1207dnl ====================================================
Note: See TracBrowser for help on using the repository browser.