source: trunk/processor/processor.m4 @ 662

Last change on this file since 662 was 662, checked in by moo, 5 years ago

back patch __FILE and __DIR on cache restore

  • Property svn:eol-style set to native
File size: 22.4 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    return;
88    ', `
89        dnl IFDASM else
90        /* Variable information */
91dnl {{{ zvalue_value
92        DISABLECHECK(`
93        switch ((Z_TYPE_P(src) & IS_CONSTANT_TYPE_MASK)) {
94            case IS_LONG:
95            case IS_RESOURCE:
96            case IS_BOOL:
97                DISPATCH(long, value.lval)
98                break;
99            case IS_DOUBLE:
100                DISPATCH(double, value.dval)
101                break;
102            case IS_NULL:
103                IFDPRINT(`INDENT()`'fprintf(stderr, "\tNULL\n");')
104                break;
105
106            case IS_CONSTANT:
107#ifdef IS_UNICODE
108                if (UG(unicode)) {
109                    goto proc_unicode;
110                }
111#endif
112            case IS_STRING:
113#ifdef FLAG_IS_BC
114            case FLAG_IS_BC:
115#endif
116                DISPATCH(int, value.str.len)
117                PROC_STRING_L(value.str.val, value.str.len)
118                break;
119#ifdef IS_UNICODE
120            case IS_UNICODE:
121proc_unicode:
122                DISPATCH(int32_t, value.uni.len)
123                PROC_ZSTRING_L(1, value.uni.val, value.uni.len)
124                break;
125#endif
126
127            case IS_ARRAY:
128            case IS_CONSTANT_ARRAY:
129                STRUCT_P(HashTable, value.ht, HashTable_zval_ptr)
130                break;
131
132            case IS_OBJECT:
133                IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
134                dnl STRUCT(value.obj)
135#ifndef ZEND_ENGINE_2
136                STRUCT_P(zend_class_entry, value.obj.ce)
137                STRUCT_P(HashTable, value.obj.properties, HashTable_zval_ptr)
138#endif
139                break;
140
141            default:
142                assert(0);
143        }
144        ')
145dnl }}}
146        DONE(value)
147        DISPATCH(zval_data_type, type)
148#ifdef ZEND_ENGINE_2_3
149        DISPATCH(zend_uchar, is_ref__gc)
150#else
151        DISPATCH(zend_uchar, is_ref)
152#endif
153
154#ifdef ZEND_ENGINE_2_3
155        DISPATCH(zend_uint, refcount__gc)
156#elif defined(ZEND_ENGINE_2)
157        DISPATCH(zend_uint, refcount)
158#else
159        DISPATCH(zend_ushort, refcount)
160#endif
161    ')dnl IFDASM
162')
163dnl }}}
164DEF_STRUCT_P_FUNC(`zval_ptr', , `dnl {{{
165    IFDASM(`
166        pushdefFUNC_NAME(`zval')
167        FUNC_NAME (dst, src[0] TSRMLS_CC);
168        popdef(`FUNC_NAME')
169    ', `
170        do {
171            IFCALCCOPY(`
172                if (processor->reference) {
173                    zval_ptr *ppzv;
174                    if (zend_hash_find(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void **) &ppzv) == SUCCESS) {
175                        IFCOPY(`
176                            dst[0] = *ppzv;
177                            /* *dst is updated */
178                            dnl fprintf(stderr, "*dst is set to %p, KIND is_shm %d\n", dst[0], xc_is_shm(dst[0]));
179                        ')
180                        IFCALCSTORE(`processor->have_references = 1;')
181                        IFSTORE(`assert(xc_is_shm(dst[0]));')
182                        IFRESTORE(`assert(!xc_is_shm(dst[0]));')
183                        break;
184                    }
185                }
186            ')
187           
188            ALLOC(dst[0], zval)
189            IFCALCCOPY(`
190                if (processor->reference) {
191                    IFCALC(`
192                        /* make dummy */
193                        zval_ptr pzv = (zval_ptr)-1;
194                    ', `
195                        zval_ptr pzv = dst[0];
196                        FIXPOINTER_EX(zval, pzv)
197                    ')
198                    if (zend_hash_add(&processor->zvalptrs, (char *) &src[0], sizeof(src[0]), (void *) &pzv, sizeof(pzv), NULL) == SUCCESS) {
199                        /* first add, go on */
200                        dnl fprintf(stderr, "mark[%p] = %p\n", src[0], pzv);
201                    }
202                    else {
203                        assert(0);
204                    }
205                }
206            ')
207            IFCOPY(`
208                dnl fprintf(stderr, "copy from %p to %p\n", src[0], dst[0]);
209            ')
210            IFDPRINT(`INDENT()`'fprintf(stderr, "[%p] ", src[0]);')
211            STRUCT_P_EX(zval, dst[0], src[0], `[0]', `', ` ')
212            FIXPOINTER_EX(zval, dst[0])
213        } while (0);
214    ')
215    DONE_SIZE(sizeof(zval_ptr))
216')
217dnl }}}
218dnl {{{ zend_arg_info
219#ifdef ZEND_ENGINE_2
220DEF_STRUCT_P_FUNC(`zend_arg_info', , `
221    DISPATCH(zend_uint, name_len)
222    PROC_ZSTRING_L(, name, name_len)
223    DISPATCH(zend_uint, class_name_len)
224    PROC_ZSTRING_L(, class_name, class_name_len)
225    DISPATCH(zend_bool, array_type_hint)
226    DISPATCH(zend_bool, allow_null)
227    DISPATCH(zend_bool, pass_by_reference)
228    DISPATCH(zend_bool, return_reference)
229    DISPATCH(int, required_num_args)
230')
231#endif
232dnl }}}
233#ifdef HAVE_XCACHE_CONSTANT
234DEF_STRUCT_P_FUNC(`zend_constant', , `dnl {{{
235    STRUCT(zval, value)
236    DISPATCH(int, flags)
237    DISPATCH(uint, name_len)
238    pushdef(`emalloc', `malloc($1)')
239    pushdef(`ecalloc', `calloc($1, $2)')
240    PROC_ZSTRING_N(, name, name_len)
241    popdef(`ecalloc')
242    popdef(`emalloc')
243    DISPATCH(int, module_number)
244')
245dnl }}}
246#endif
247DEF_STRUCT_P_FUNC(`zend_function', , `dnl {{{
248    DISABLECHECK(`
249    switch (src->type) {
250    case ZEND_INTERNAL_FUNCTION:
251    case ZEND_OVERLOADED_FUNCTION:
252        IFNOTMEMCPY(`IFCOPY(`memcpy(dst, src, sizeof(src[0]));')')
253        break;
254
255    case ZEND_USER_FUNCTION:
256    case ZEND_EVAL_CODE:
257        DONE(type)
258        STRUCT(zend_op_array, op_array)
259        break;
260
261    default:
262        assert(0);
263    }
264    ')
265    DONE_SIZE(sizeof(src[0]))
266')
267dnl }}}
268dnl {{{ zend_property_info
269#ifdef ZEND_ENGINE_2
270DEF_STRUCT_P_FUNC(`zend_property_info', , `
271    DISPATCH(zend_uint, flags)
272    DISPATCH(int, name_length)
273    PROC_ZSTRING_L(, name, name_length)
274    DISPATCH(ulong, h)
275#ifdef ZEND_ENGINE_2_1
276    DISPATCH(int, doc_comment_len)
277    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
278#endif
279    dnl isnt in php6 yet
280#if defined(ZEND_ENGINE_2_2)
281    PROC_CLASS_ENTRY_P(ce)
282#endif
283')
284#endif
285dnl }}}
286DEF_STRUCT_P_FUNC(`zend_class_entry', , `dnl {{{
287    IFCALCCOPY(`
288        processor->active_class_entry_src = src;
289        IFCOPY(`processor->active_class_entry_dst = dst;')
290    ')
291    DISPATCH(char, type)
292    DISPATCH(zend_uint, name_length)
293    PROC_ZSTRING_L(, name, name_length)
294    IFRESTORE(`
295#ifndef ZEND_ENGINE_2
296        /* just copy parent and resolve on install_class */
297        COPY(parent)
298#else
299        PROC_CLASS_ENTRY_P(parent)
300#endif
301    ', `
302        PROC_CLASS_ENTRY_P(parent)
303    ')
304#ifdef ZEND_ENGINE_2
305    DISPATCH(int, refcount)
306#else
307    STRUCT_P(int, refcount)
308#endif
309    DISPATCH(zend_bool, constants_updated)
310#ifdef ZEND_ENGINE_2
311    DISPATCH(zend_uint, ce_flags)
312#endif
313
314    STRUCT(HashTable, default_properties, HashTable_zval_ptr)
315    IFCOPY(`dst->builtin_functions = src->builtin_functions;')
316    DONE(builtin_functions)
317#ifdef ZEND_ENGINE_2
318    STRUCT(HashTable, properties_info, HashTable_zend_property_info)
319#   ifdef ZEND_ENGINE_2_1
320    STRUCT(HashTable, default_static_members, HashTable_zval_ptr)
321    IFCOPY(`dst->static_members = &dst->default_static_members;')
322    DONE(static_members)
323#   else
324    STRUCT_P(HashTable, static_members, HashTable_zval_ptr)
325#   endif
326    STRUCT(HashTable, constants_table, HashTable_zval_ptr)
327
328    dnl runtime binding: ADD_INTERFACE will deal with it
329    IFRESTORE(`
330        if (src->num_interfaces) {
331            CALLOC(dst->interfaces, zend_class_entry*, src->num_interfaces)
332            DONE(`interfaces')
333        }
334        else {
335            COPYNULL(interfaces)
336        }
337    ')
338    IFDASM(`
339        if (src->num_interfaces) {
340            /*
341            int i;
342            zval *arr;
343            ALLOC_INIT_ZVAL(arr);
344            array_init(arr);
345            for (i = 0; i < src->num_interfaces; i ++) {
346                zval *zv;
347                ALLOC_INIT_ZVAL(zv);
348                ZVAL_STRING(src->num_interfaces);
349            }
350            add_assoc_zval_ex(dst, ZEND_STRS("interfaces"), arr);
351            */
352            DONE(`interfaces')
353        }
354        else {
355            COPYNULL(interfaces)
356        }
357    ')
358    IFRESTORE(`', `
359        IFDASM(`', `
360            DONE(`interfaces')
361        ')
362    ')
363    DISPATCH(zend_uint, num_interfaces)
364
365    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
366    DISPATCH(zend_uint, line_start)
367    DISPATCH(zend_uint, line_end)
368#ifdef ZEND_ENGINE_2_1
369    DISPATCH(zend_uint, doc_comment_len)
370    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
371#endif
372    /* # NOT DONE */
373    COPY(serialize_func)
374    COPY(unserialize_func)
375    COPY(iterator_funcs)
376    COPY(create_object)
377    COPY(get_iterator)
378    COPY(interface_gets_implemented)
379#ifdef ZEND_ENGINE_2_3
380    COPY(get_static_method)
381#endif
382    COPY(serialize)
383    COPY(unserialize)
384    /* deal with it inside xc_fix_method */
385    SETNULL(constructor)
386    COPY(destructor)
387    COPY(clone)
388    COPY(__get)
389    COPY(__set)
390/* should be >5.1 */
391#ifdef ZEND_ENGINE_2_1
392    COPY(__unset)
393    COPY(__isset)
394# if defined(ZEND_ENGINE_2_2) || PHP_MAJOR_VERSION >= 6
395    COPY(__tostring)
396# endif
397#endif
398    COPY(__call)
399#ifdef ZEND_CALLSTATIC_FUNC_NAME
400    COPY(__callstatic)
401#endif
402    /* # NOT DONE */
403    COPY(module)
404#else
405    COPY(handle_function_call)
406    COPY(handle_property_get)
407    COPY(handle_property_set)
408#endif
409    dnl must do after SETNULL(constructor) and dst->parent
410    STRUCT(HashTable, function_table, HashTable_zend_function)
411    IFRESTORE(`dst->function_table.pDestructor = ZEND_FUNCTION_DTOR;')
412    IFCALCCOPY(`
413        processor->active_class_entry_src = NULL;
414        IFCOPY(`processor->active_class_entry_dst = NULL;')
415    ')
416')
417dnl }}}
418DEF_STRUCT_P_FUNC(`znode', , `dnl {{{
419    DISPATCH(int, op_type)
420
421#ifdef IS_CV
422#   define XCACHE_IS_CV IS_CV
423#else
424/* compatible with zend optimizer */
425#   define XCACHE_IS_CV 16
426#endif
427    assert(src->op_type == IS_CONST ||
428        src->op_type == IS_VAR ||
429        src->op_type == XCACHE_IS_CV ||
430        src->op_type == IS_TMP_VAR ||
431        src->op_type == IS_UNUSED);
432    dnl dirty dispatch
433    DISABLECHECK(`
434    switch (src->op_type) {
435        case IS_CONST:
436            STRUCT(zval, u.constant)
437            break;
438        IFCOPY(`
439            IFNOTMEMCPY(`
440                default:
441                    memcpy(&dst->u, &src->u, sizeof(src->u));
442            ')
443        ', `
444        case IS_VAR:
445        case IS_TMP_VAR:
446        case XCACHE_IS_CV:
447            DISPATCH(zend_uint, u.var)
448            DISPATCH(zend_uint, u.EA.type)
449            break;
450        case IS_UNUSED:
451            IFDASM(`DISPATCH(zend_uint, u.var)')
452            DISPATCH(zend_uint, u.opline_num)
453#ifndef ZEND_ENGINE_2
454            DISPATCH(zend_uint, u.fetch_type)
455#endif
456            DISPATCH(zend_uint, u.EA.type)
457            break;
458        ')
459    }
460    ')
461    DONE(u)
462#undef XCACHE_IS_CV
463')
464dnl }}}
465DEF_STRUCT_P_FUNC(`zend_op', , `dnl {{{
466    DISPATCH(zend_uchar, opcode)
467    STRUCT(znode, result)
468    STRUCT(znode, op1)
469    STRUCT(znode, op2)
470    DISPATCH(ulong, extended_value)
471    DISPATCH(uint, lineno)
472#ifdef ZEND_ENGINE_2_1
473    IFCOPY(`
474        switch (src->opcode) {
475#ifdef ZEND_GOTO
476            case ZEND_GOTO:
477#endif
478            case ZEND_JMP:
479                dst->op1.u.jmp_addr = processor->active_opcodes_dst + (src->op1.u.jmp_addr - processor->active_opcodes_src);
480                break;
481
482            case ZEND_JMPZ:
483            case ZEND_JMPNZ:
484            case ZEND_JMPZ_EX:
485            case ZEND_JMPNZ_EX:
486#ifdef ZEND_JMP_SET
487            case ZEND_JMP_SET:
488#endif
489                dst->op2.u.jmp_addr = processor->active_opcodes_dst + (src->op2.u.jmp_addr - processor->active_opcodes_src);
490                break;
491
492            default:
493                break;
494        }
495    ')
496    DISPATCH(opcode_handler_t, handler)
497#endif
498')
499dnl }}}
500DEF_STRUCT_P_FUNC(`zend_op_array', , `dnl {{{
501    IFRESTORE(`
502    const xc_op_array_info_t *op_array_info = &processor->active_op_array_infos_src[processor->active_op_array_index];
503    dnl shadow copy must NOT meet:
504    dnl readonly_protection=on
505    dnl main op_array && have early binding
506#ifdef ZEND_COMPILE_DELAYED_BINDING
507    zend_bool need_early_binding = 0;
508#else
509    zend_bool need_early_binding = processor->php_src->have_early_binding;
510#endif
511    zend_bool shallow_copy = !processor->readonly_protection && !(src == processor->php_src->op_array && need_early_binding);
512    if (shallow_copy) {
513        zend_bool gc_arg_info = 0;
514        int gc_opcodes        = 0;
515        /* really fast shallow copy */
516        memcpy(dst, src, sizeof(src[0]));
517        dst->refcount[0] = 1000;
518        /* deep */
519        STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
520#ifdef ZEND_ENGINE_2
521        STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
522        gc_arg_info = 1;
523#endif
524        if (op_array_info->oplineinfo_cnt) {
525            gc_opcodes = 1;
526            COPY_N_EX(last, zend_op, opcodes)
527        }
528        if (gc_arg_info || gc_opcodes) {
529            xc_gc_op_array_t gc_op_array;
530#ifdef ZEND_ENGINE_2
531            gc_op_array.num_args = gc_arg_info ? dst->num_args : 0;
532            gc_op_array.arg_info = gc_arg_info ? dst->arg_info : NULL;
533#endif
534            gc_op_array.last     = gc_opcodes > 1 ? dst->last : 0;
535            gc_op_array.opcodes  = gc_opcodes ? dst->opcodes : NULL;
536            xc_gc_add_op_array(&gc_op_array TSRMLS_CC);
537        }
538        define(`SKIPASSERT_ONCE')
539    }
540    else
541    ')
542    do {
543    dnl RESTORE is done above!
544
545    /* Common elements */
546    DISPATCH(zend_uchar, type)
547    PROC_ZSTRING(, function_name)
548#ifdef ZEND_ENGINE_2
549    DISPATCH(zend_uint, fn_flags)
550    STRUCT_ARRAY(num_args, zend_arg_info, arg_info)
551    DISPATCH(zend_uint, num_args)
552    DISPATCH(zend_uint, required_num_args)
553    DISPATCH(zend_bool, pass_rest_by_reference)
554#else
555    if (src->arg_types) {
556        ALLOC(dst->arg_types, zend_uchar, src->arg_types[0] + 1)
557        IFCOPY(`memcpy(dst->arg_types, src->arg_types, sizeof(src->arg_types[0]) * (src->arg_types[0]+1));')
558        IFDASM(`do {
559            int i;
560            zval *zv;
561            ALLOC_INIT_ZVAL(zv);
562            array_init(zv);
563            for (i = 0; i < src->arg_types[0]; i ++) {
564                add_next_index_long(zv, src->arg_types[i + 1]);
565            }
566            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
567        } while (0);')
568        DONE(arg_types)
569    }
570    else {
571        IFDASM(`do {
572            /* empty array */
573            zval *zv;
574            ALLOC_INIT_ZVAL(zv);
575            array_init(zv);
576            add_assoc_zval_ex(dst, ZEND_STRS("arg_types"), zv);
577        } while (0);
578        DONE(arg_types)
579        ', `
580        COPYNULL(arg_types)
581        ')
582    }
583#endif
584    DISPATCH(unsigned char, return_reference)
585    /* END of common elements */
586#ifdef IS_UNICODE
587    dnl SETNULL(u_twin)
588#endif
589
590    STRUCT_P(zend_uint, refcount)
591    UNFIXPOINTER(zend_uint, refcount)
592    IFSTORE(`dst->refcount[0] = 1;')
593
594    pushdef(`AFTER_ALLOC', `IFCOPY(`
595        processor->active_opcodes_dst = dst->opcodes;
596        processor->active_opcodes_src = src->opcodes;
597    ')')
598    STRUCT_ARRAY(last, zend_op, opcodes)
599    popdef(`AFTER_ALLOC')
600    DISPATCH(zend_uint, last)
601    IFCOPY(`dst->size = src->last;DONE(size)', `DISPATCH(zend_uint, size)')
602
603#ifdef IS_CV
604    STRUCT_ARRAY(last_var, zend_compiled_variable, vars)
605    DISPATCH(int, last_var)
606    IFCOPY(`dst->size_var = src->last_var;DONE(size_var)', `DISPATCH(zend_uint, size_var)')
607#else
608    dnl zend_cv.m4 is illegal to be made public, don not ask me for it
609    IFDASM(`
610        sinclude(srcdir`/processor/zend_cv.m4')
611        ')
612#endif
613
614    DISPATCH(zend_uint, T)
615
616    STRUCT_ARRAY(last_brk_cont, zend_brk_cont_element, brk_cont_array)
617    DISPATCH(zend_uint, last_brk_cont)
618    DISPATCH(zend_uint, current_brk_cont)
619#ifndef ZEND_ENGINE_2
620    DISPATCH(zend_bool, uses_globals)
621#endif
622
623#ifdef ZEND_ENGINE_2
624    STRUCT_ARRAY(last_try_catch, zend_try_catch_element, try_catch_array)
625    DISPATCH(int, last_try_catch)
626#endif
627
628    STRUCT_P(HashTable, static_variables, HashTable_zval_ptr)
629
630    COPY(start_op)
631    DISPATCH(int, backpatch_count)
632#ifdef ZEND_ENGINE_2_3
633    DISPATCH(zend_uint, this_var)
634#endif
635
636    DISPATCH(zend_bool, done_pass_two)
637    /* 5.0 <= ver < 5.3 */
638#if defined(ZEND_ENGINE_2) && !defined(ZEND_ENGINE_2_3)
639    DISPATCH(zend_bool, uses_this)
640#endif
641
642    IFRESTORE(`COPY(filename)', `PROC_STRING(filename)')
643#ifdef IS_UNICODE
644    IFRESTORE(`
645        COPY(script_encoding)
646    ', `
647        PROC_STRING(script_encoding)
648    ')
649#endif
650#ifdef ZEND_ENGINE_2
651    DISPATCH(zend_uint, line_start)
652    DISPATCH(zend_uint, line_end)
653    DISPATCH(int, doc_comment_len)
654    PROC_ZSTRING_L(, doc_comment, doc_comment_len)
655#endif
656#ifdef ZEND_COMPILE_DELAYED_BINDING
657    DISPATCH(zend_uint, early_binding);
658#endif
659
660    /* reserved */
661    DONE(reserved)
662#if defined(HARDENING_PATCH) && HARDENING_PATCH
663    DISPATCH(zend_bool, created_by_eval)
664#endif
665    } while (0);
666    IFRESTORE(`xc_fix_op_array_info(processor->php_src, dst, !shallow_copy, op_array_info TSRMLS_CC);')
667
668#ifdef ZEND_ENGINE_2
669    dnl mark it as -1 on store, and lookup parent on restore
670    IFSTORE(`dst->prototype = (processor->active_class_entry_src && src->prototype) ? (zend_function *) -1 : NULL; DONE(prototype)', `
671            IFRESTORE(`do {
672                zend_function *parent;
673                if (src->prototype != NULL
674                 && zend_u_hash_find(&(processor->active_class_entry_dst->parent->function_table),
675                        UG(unicode) ? IS_UNICODE : IS_STRING,
676                        src->function_name, xc_zstrlen(UG(unicode) ? IS_UNICODE : IS_STRING, src->function_name) + 1,
677                        (void **) &parent) == SUCCESS) {
678                    /* see do_inherit_method_check() */
679                    if ((parent->common.fn_flags & ZEND_ACC_ABSTRACT)) {
680                      dst->prototype = parent;
681                    } else if (!(parent->common.fn_flags & ZEND_ACC_CTOR) || (parent->common.prototype && (parent->common.prototype->common.scope->ce_flags & ZEND_ACC_INTERFACE))) {
682                        /* ctors only have a prototype if it comes from an interface */
683                        dst->prototype = parent->common.prototype ? parent->common.prototype : parent;
684                    }
685                    else {
686                        dst->prototype = NULL;
687                    }
688                }
689                else {
690                    dst->prototype = NULL;
691                }
692                DONE(prototype)
693            } while (0);
694            ', `
695                COPYNULL(prototype)
696            ')
697    ')
698#endif
699
700#ifdef ZEND_ENGINE_2
701    PROC_CLASS_ENTRY_P(scope)
702    IFCOPY(`
703        if (src->scope) {
704            xc_fix_method(processor, dst TSRMLS_CC);
705        }
706    ')
707#endif
708
709    IFRESTORE(`
710        if (xc_have_op_array_ctor) {
711            zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) xc_zend_extension_op_array_ctor_handler, dst TSRMLS_CC);
712        }
713    ')
714')
715dnl }}}
716
717#ifdef HAVE_XCACHE_CONSTANT
718DEF_STRUCT_P_FUNC(`xc_constinfo_t', , `dnl {{{
719    DISPATCH(zend_uint, key_size)
720#ifdef IS_UNICODE
721    DISPATCH(zend_uchar, type)
722#endif
723    IFRESTORE(`COPY(key)', `
724        PROC_ZSTRING_N(type, key, key_size)
725    ')
726    DISPATCH(ulong, h)
727    STRUCT(zend_constant, constant)
728')
729dnl }}}
730#endif
731DEF_STRUCT_P_FUNC(`xc_op_array_info_t', , `dnl {{{
732    DISPATCH(zend_uint, oplineinfo_cnt)
733    DISPATCH_ARRAY(oplineinfo_cnt, int, oplineinfos)
734')
735dnl }}}
736DEF_STRUCT_P_FUNC(`xc_funcinfo_t', , `dnl {{{
737    DISPATCH(zend_uint, key_size)
738#ifdef IS_UNICODE
739    DISPATCH(zend_uchar, type)
740#endif
741    IFRESTORE(`COPY(key)', `
742        PROC_ZSTRING_N(type, key, key_size)
743    ')
744    DISPATCH(ulong, h)
745    IFRESTORE(`COPY(op_array_info)', `
746        STRUCT(xc_op_array_info_t, op_array_info)
747    ')
748    IFRESTORE(`
749        processor->active_op_array_infos_src = &dst->op_array_info;
750        processor->active_op_array_index = 0;
751    ')
752    STRUCT(zend_function, func)
753')
754dnl }}}
755DEF_STRUCT_P_FUNC(`xc_classinfo_t', , `dnl {{{
756    DISPATCH(zend_uint, key_size)
757#ifdef IS_UNICODE
758    DISPATCH(zend_uchar, type)
759#endif
760    IFRESTORE(`COPY(key)', `
761        PROC_ZSTRING_N(type, key, key_size)
762    ')
763    DISPATCH(ulong, h)
764    DISPATCH(zend_uint, methodinfo_cnt)
765    IFRESTORE(`COPY(methodinfos)', `
766        STRUCT_ARRAY(methodinfo_cnt, xc_op_array_info_t, methodinfos)
767    ')
768    IFRESTORE(`
769        processor->active_op_array_infos_src = dst->methodinfos;
770        processor->active_op_array_index = 0;
771    ')
772#ifdef ZEND_ENGINE_2
773    STRUCT_P(zend_class_entry, cest)
774#else
775    STRUCT(zend_class_entry, cest)
776#endif
777#ifndef ZEND_COMPILE_DELAYED_BINDING
778    DISPATCH(int, oplineno)
779#endif
780')
781dnl }}}
782#ifdef ZEND_ENGINE_2_1
783DEF_STRUCT_P_FUNC(`xc_autoglobal_t', , `dnl {{{
784    DISPATCH(zend_uint, key_len)
785#ifdef IS_UNICODE
786    DISPATCH(zend_uchar, type)
787#endif
788    IFRESTORE(`COPY(key)', `
789        PROC_ZSTRING_L(type, key, key_len)
790    ')
791    DISPATCH(ulong, h)
792')
793dnl }}}
794#endif
795#ifdef E_STRICT
796DEF_STRUCT_P_FUNC(`xc_compilererror_t', , `dnl {{{
797    DISPATCH(int, type)
798    DISPATCH(uint, lineno)
799    DISPATCH(int, error_len)
800    PROC_STRING_L(error, error_len)
801')
802dnl }}}
803#endif
804DEF_STRUCT_P_FUNC(`xc_entry_data_php_t', , `dnl {{{
805    IFCOPY(`
806        processor->php_dst = dst;
807        processor->php_src = src;
808    ')
809
810    DISPATCH(xc_hash_value_t, hvalue)
811    /* skip */
812    DONE(next)
813    COPY(cache)
814    DISPATCH(xc_md5sum_t, md5)
815    DISPATCH(zend_ulong, refcount)
816
817    DISPATCH(size_t, sourcesize)
818    DISPATCH(zend_ulong, hits)
819    DISPATCH(size_t, size)
820
821    DISPATCH(int, filepath_len)
822    IFRESTORE(`COPY(filepath)', `PROC_STRING_L(filepath, filepath_len)')
823    DISPATCH(int, dirpath_len)
824    IFRESTORE(`COPY(dirpath)', `PROC_STRING_L(dirpath, dirpath_len)')
825#ifdef IS_UNICODE
826    DISPATCH(int, ufilepath_len)
827    IFRESTORE(`COPY(ufilepath)', `PROC_USTRING_L(ufilepath, ufilepath_len)')
828    DISPATCH(int, udirpath_len)
829    IFRESTORE(`COPY(udirpath)', `PROC_USTRING_L(udirpath, udirpath_len)')
830#endif
831
832    IFRESTORE(`COPY(op_array_info)', `
833        STRUCT(xc_op_array_info_t, op_array_info)
834    ')
835    IFRESTORE(`
836        processor->active_op_array_infos_src = &dst->op_array_info;
837        processor->active_op_array_index = 0;
838    ')
839    STRUCT_P(zend_op_array, op_array)
840
841#ifdef HAVE_XCACHE_CONSTANT
842    DISPATCH(zend_uint, constinfo_cnt)
843    STRUCT_ARRAY(constinfo_cnt, xc_constinfo_t, constinfos)
844#endif
845
846    DISPATCH(zend_uint, funcinfo_cnt)
847    STRUCT_ARRAY(funcinfo_cnt, xc_funcinfo_t, funcinfos)
848
849    DISPATCH(zend_uint, classinfo_cnt)
850    STRUCT_ARRAY(classinfo_cnt, xc_classinfo_t, classinfos, , IFRESTORE(`processor->active_class_index'))
851#ifdef ZEND_ENGINE_2_1
852    DISPATCH(zend_uint, autoglobal_cnt)
853    IFRESTORE(`
854        COPY(autoglobals)
855    ', `
856        STRUCT_ARRAY(autoglobal_cnt, xc_autoglobal_t, autoglobals)
857    ')
858#endif
859#ifdef E_STRICT
860    DISPATCH(zend_uint, compilererror_cnt)
861    IFRESTORE(`
862        COPY(compilererrors)
863    ', `
864        STRUCT_ARRAY(compilererror_cnt, xc_compilererror_t, compilererrors)
865    ')
866#endif
867#ifndef ZEND_COMPILE_DELAYED_BINDING
868    DISPATCH(zend_bool, have_early_binding)
869#endif
870    DISPATCH(zend_bool, have_references)
871')
872dnl }}}
873DEF_STRUCT_P_FUNC(`xc_entry_data_var_t', , `dnl {{{
874    IFDPRINT(`INDENT()`'fprintf(stderr, "zval:value");')
875    STRUCT_P_EX(zval_ptr, dst->value, src->value, `value', `', `&')
876    DISPATCH(zend_bool, have_references)
877    DONE(value)
878')
879dnl }}}
880dnl {{{ xc_entry_t
881DEF_STRUCT_P_FUNC(`xc_entry_t', , `
882    DISPATCH(xc_entry_type_t, type)
883    DISPATCH(size_t, size)
884
885    DISPATCH(xc_hash_value_t, hvalue)
886    COPY(cache)
887    /* skip */
888    DONE(next)
889
890    IFSTORE(`dst->refcount = 0; DONE(refcount)', `DISPATCH(long, refcount)')
891
892    DISPATCH(time_t, ctime)
893    DISPATCH(time_t, atime)
894    DISPATCH(time_t, dtime)
895    DISPATCH(long, ttl)
896    DISPATCH(zend_ulong, hits)
897#ifdef IS_UNICODE
898    DISPATCH(zend_uchar, name_type)
899#endif
900    dnl {{{ name
901    DISABLECHECK(`
902#ifdef IS_UNICODE
903        if (src->name_type == IS_UNICODE) {
904            DISPATCH(int32_t, name.ustr.len)
905        }
906        else {
907            DISPATCH(int, name.str.len)
908        }
909#else
910        DISPATCH(int, name.str.len)
911#endif
912        IFRESTORE(`COPY(name.str.val)', `
913#ifdef IS_UNICODE
914            PROC_ZSTRING_L(name_type, name.uni.val, name.uni.len)
915#else
916            PROC_STRING_L(name.str.val, name.str.len)
917#endif
918        ')
919    ')
920    DONE(name)
921    dnl }}}
922
923    dnl {{{ data
924    DISABLECHECK(`
925        switch (src->type) {
926        case XC_TYPE_PHP:
927            IFCALCCOPY(`COPY(data.php)', `STRUCT_P(xc_entry_data_php_t, data.php)')
928            break;
929
930        case XC_TYPE_VAR:
931            STRUCT_P(xc_entry_data_var_t, data.var)
932            break;
933
934        default:
935            assert(0);
936        }
937    ')
938    DONE(data)
939    dnl }}}
940    DISPATCH(time_t, mtime)
941#ifdef HAVE_INODE
942    DISPATCH(int, device)
943    DISPATCH(int, inode)
944#endif
945')
946dnl }}}
947dnl ====================================================
Note: See TracBrowser for help on using the repository browser.