source: trunk/processor/processor.m4 @ 779

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

cacher: fix segv if oplineinfo is used for __FILE __DIR

  • Property svn:eol-style set to native
File size: 27.9 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    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
500    dnl dirty dispatch
501    DISABLECHECK(`
502    switch ((src->$1_type & ~EXT_TYPE_UNUSED)) {
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
538DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
539    DISPATCH(int, op_type)
540
541#ifdef IS_CV
542#   define XCACHE_IS_CV IS_CV
543#else
544/* compatible with zend optimizer */
545#   define XCACHE_IS_CV 16
546#endif
547    assert(src->op_type == IS_CONST ||
548        src->op_type == IS_VAR ||
549        src->op_type == XCACHE_IS_CV ||
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:
566        case XCACHE_IS_CV:
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)
582#if 0
583    DONE(EA)
584#endif
585#undef XCACHE_IS_CV
586')
587dnl }}}
588#endif
589DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
590    DISPATCH(zend_uchar, opcode)
591#ifdef ZEND_ENGINE_2_4
592    UNION_znode_op(result)
593    UNION_znode_op(op1)
594    UNION_znode_op(op2)
595#else
596    STRUCT(znode, result)
597    STRUCT(znode, op1)
598    STRUCT(znode, op2)
599#endif
600    DISPATCH(ulong, extended_value)
601    DISPATCH(uint, lineno)
602#ifdef ZEND_ENGINE_2_1
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
608    IFCOPY(`
609        switch (src->opcode) {
610#ifdef ZEND_GOTO
611            case ZEND_GOTO:
612#endif
613            case ZEND_JMP:
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);
615                Z_OP(dst->op1).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op1).jmp_addr - processor->active_opcodes_src);
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);
617                break;
618
619            case ZEND_JMPZ:
620            case ZEND_JMPNZ:
621            case ZEND_JMPZ_EX:
622            case ZEND_JMPNZ_EX:
623#ifdef ZEND_JMP_SET
624            case ZEND_JMP_SET:
625#endif
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);
627                Z_OP(dst->op2).jmp_addr = processor->active_opcodes_dst + (Z_OP(src->op2).jmp_addr - processor->active_opcodes_src);
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);
629                break;
630
631            default:
632                break;
633        }
634    ')
635    DISPATCH(opcode_handler_t, handler)
636#endif
637')
638dnl }}}
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
647DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
648    IFRESTORE(`
649    const xc_op_array_info_t *op_array_info = &processor->active_op_array_infos_src[processor->active_op_array_index++];
650    dnl shadow copy must NOT meet:
651    dnl readonly_protection=on
652    dnl main op_array && have early binding
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
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;
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)
667#ifdef ZEND_ENGINE_2
668        STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
669        gc_arg_info = 1;
670#endif
671        IFRESTORE(`dst->filename = processor->entry_src->filepath;')
672#ifndef ZEND_ENGINE_2_4
673        if (op_array_info->oplineinfo_cnt) {
674            zend_op *opline, *end;
675            gc_opcodes = 1;
676            COPY_N_EX(last, zend_op, opcodes)
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            }
701        }
702#endif
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        }
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)
722    PROC_ZSTRING(, function_name)
723#ifdef ZEND_ENGINE_2
724    DISPATCH(zend_uint, fn_flags)
725    STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
726    DISPATCH(zend_uint, num_args)
727    DISPATCH(zend_uint, required_num_args)
728#   ifndef ZEND_ENGINE_2_4
729    DISPATCH(zend_bool, pass_rest_by_reference)
730#   endif
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
761#ifndef ZEND_ENGINE_2_4
762    DISPATCH(unsigned char, return_reference)
763#endif
764    /* END of common elements */
765#ifdef IS_UNICODE
766    dnl SETNULL(u_twin)
767#endif
768
769    STRUCT_P(zend_uint, refcount)
770    UNFIXPOINTER(zend_uint, refcount)
771    IFSTORE(`dst->refcount[0] = 1;')
772
773    pushdef(`AFTER_ALLOC', `IFCOPY(`
774#ifndef NDEBUG
775        processor->active_op_array_dst = dst;
776        processor->active_op_array_src = src;
777#endif
778        processor->active_opcodes_dst = dst->opcodes;
779        processor->active_opcodes_src = src->opcodes;
780    ')')
781    STRUCT_ARRAY(last, zend_op, opcodes)
782    popdef(`AFTER_ALLOC')
783    DISPATCH(zend_uint, last)
784#ifndef ZEND_ENGINE_2_4
785    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
786#endif
787
788#ifdef IS_CV
789    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
790    DISPATCH(int, last_var)
791#   ifndef ZEND_ENGINE_2_4
792    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
793#   endif
794#else
795    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
796    IFDASM(`
797        sinclude(srcdir`/processor/zend_cv.m4')
798        ')
799#endif
800
801    DISPATCH(zend_uint, T)
802
803    STRUCT_ARRAY(last_brk_cont, zend_brk_cont_element, brk_cont_array)
804    DISPATCH(zend_uint, last_brk_cont)
805#ifndef ZEND_ENGINE_2_4
806    DISPATCH(zend_uint, current_brk_cont)
807#endif
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
819#ifndef ZEND_ENGINE_2_4
820    COPY(start_op)
821    DISPATCH(int, backpatch_count)
822#endif
823#ifdef ZEND_ENGINE_2_3
824    DISPATCH(zend_uint, this_var)
825#endif
826
827#ifndef ZEND_ENGINE_2_4
828    DISPATCH(zend_bool, done_pass_two)
829#endif
830    /* 5.0 <= ver < 5.3 */
831#if defined(ZEND_ENGINE_2) && !defined(ZEND_ENGINE_2_3)
832    DISPATCH(zend_bool, uses_this)
833#endif
834
835    IFRESTORE(`dst->filename = processor->entry_src->filepath;DONE(filename)', `PROC_STRING(filename)')
836#ifdef IS_UNICODE
837    IFRESTORE(`
838        COPY(script_encoding)
839    ', `
840        PROC_STRING(script_encoding)
841    ')
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)
847    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
848#endif
849#ifdef ZEND_COMPILE_DELAYED_BINDING
850    DISPATCH(zend_uint, early_binding);
851#endif
852
853    /* reserved */
854    DONE(reserved)
855#if defined(HARDENING_PATCH) && HARDENING_PATCH
856    DISPATCH(zend_bool, created_by_eval)
857#endif
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
865    } while (0);
866    IFRESTORE(`xc_fix_op_array_info(processor->entry_src, processor->php_src, dst, !shallow_copy, op_array_info TSRMLS_CC);')
867
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,
876                        src->function_name, xc_zstrlen(UG(unicode) ? IS_UNICODE : IS_STRING, src->function_name) + 1,
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    ')
898
899#endif
900
901#ifdef ZEND_ENGINE_2
902    PROC_CLASS_ENTRY_P(scope)
903    IFCOPY(`
904        if (src->scope) {
905            xc_fix_method(processor, dst TSRMLS_CC);
906        }
907    ')
908#endif
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    ')
915')
916dnl }}}
917
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)', `
925        PROC_ZSTRING_N(type, key, key_size)
926    ')
927    DISPATCH(ulong, h)
928    STRUCT(zend_constant, constant)
929')
930dnl }}}
931#endif
932DEF_STRUCT_P_FUNC(`xc_op_array_info_t', , `dnl {{{
933#ifdef ZEND_ENGINE_2_4
934    DISPATCH(zend_uint, literalinfo_cnt)
935    DISPATCH_ARRAY(literalinfo_cnt, int, literalinfos)
936#else
937    DISPATCH(zend_uint, oplineinfo_cnt)
938    DISPATCH_ARRAY(oplineinfo_cnt, int, oplineinfos)
939#endif
940')
941dnl }}}
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)', `
948        PROC_ZSTRING_N(type, key, key_size)
949    ')
950    DISPATCH(ulong, h)
951    IFRESTORE(`COPY(op_array_info)', `
952        STRUCT(xc_op_array_info_t, op_array_info)
953    ')
954    IFRESTORE(`
955        processor->active_op_array_infos_src = &src->op_array_info;
956        processor->active_op_array_index = 0;
957    ')
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)', `
967        PROC_ZSTRING_N(type, key, key_size)
968    ')
969    DISPATCH(ulong, h)
970    DISPATCH(zend_uint, methodinfo_cnt)
971    IFRESTORE(`COPY(methodinfos)', `
972        STRUCT_ARRAY(methodinfo_cnt, xc_op_array_info_t, methodinfos)
973    ')
974    IFRESTORE(`
975        processor->active_op_array_infos_src = src->methodinfos;
976        processor->active_op_array_index = 0;
977    ')
978#ifdef ZEND_ENGINE_2
979    STRUCT_P(zend_class_entry, cest)
980#else
981    STRUCT(zend_class_entry, cest)
982#endif
983#ifndef ZEND_COMPILE_DELAYED_BINDING
984    DISPATCH(int, oplineno)
985#endif
986')
987dnl }}}
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    ')
997    DISPATCH(ulong, h)
998')
999dnl }}}
1000#endif
1001#ifdef E_STRICT
1002DEF_STRUCT_P_FUNC(`xc_compilererror_t', , `dnl {{{
1003    DISPATCH(int, type)
1004    DISPATCH(uint, lineno)
1005    DISPATCH(int, error_len)
1006    PROC_STRING_L(error, error_len)
1007')
1008dnl }}}
1009#endif
1010DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
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
1023    DISPATCH(size_t, sourcesize)
1024    DISPATCH(zend_ulong, hits)
1025    DISPATCH(size_t, size)
1026
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    ')
1034    STRUCT_P(zend_op_array, op_array)
1035
1036#ifdef HAVE_XCACHE_CONSTANT
1037    DISPATCH(zend_uint, constinfo_cnt)
1038    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
1039#endif
1040
1041    DISPATCH(zend_uint, funcinfo_cnt)
1042    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
1043
1044    DISPATCH(zend_uint, classinfo_cnt)
1045    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos, , IFRESTORE(`processor->active_class_index'))
1046#ifdef ZEND_ENGINE_2_1
1047    DISPATCH(zend_uint, autoglobal_cnt)
1048    IFRESTORE(`
1049        COPY(autoglobals)
1050    ', `
1051        STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
1052    ')
1053#endif
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
1062#ifndef ZEND_COMPILE_DELAYED_BINDING
1063    DISPATCH(zend_bool, have_early_binding)
1064#endif
1065    DISPATCH(zend_bool, have_references)
1066')
1067dnl }}}
1068DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
1069    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
1070    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
1071    DISPATCH(zend_bool, have_references)
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)
1090    DISPATCH(long, ttl)
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
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        ')
1114    ')
1115    DONE(name)
1116    dnl }}}
1117
1118    dnl {{{ data
1119    DISABLECHECK(`
1120        switch (src->type) {
1121        case XC_TYPE_PHP:
1122            IFCALCCOPY(`COPY(data.php)', `STRUCT_P(xc_entry_data_php_t, data.php)')
1123            break;
1124
1125        case XC_TYPE_VAR:
1126            STRUCT_P(xc_entry_data_var_t, data.var)
1127            break;
1128
1129        default:
1130            assert(0);
1131        }
1132    ')
1133    DONE(data)
1134    dnl }}}
1135    DISPATCH(time_t, mtime)
1136#ifdef HAVE_INODE
1137    DISPATCH(int, device)
1138    DISPATCH(int, inode)
1139#endif
1140
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)')
1146#ifdef IS_UNICODE
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)')
1151#endif
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    }
1165')
1166dnl }}}
1167dnl ====================================================
Note: See TracBrowser for help on using the repository browser.