diff options
| author | Andi Gutmans <andi@php.net> | 2002-10-24 18:04:12 +0000 |
|---|---|---|
| committer | Andi Gutmans <andi@php.net> | 2002-10-24 18:04:12 +0000 |
| commit | 80109314b918e776205003212e494bfbf4a559a3 (patch) | |
| tree | 279ab88cfed27dc87b6becaf736f926949d1f415 /Zend/zend_opcode.c | |
| parent | e4becf42ed611a443afd1ea8199561478289b5ee (diff) | |
| download | php-git-80109314b918e776205003212e494bfbf4a559a3.tar.gz | |
- Improve performance of part of the jmps. More to follow.
Diffstat (limited to 'Zend/zend_opcode.c')
| -rw-r--r-- | Zend/zend_opcode.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/Zend/zend_opcode.c b/Zend/zend_opcode.c index 493d276c1a..fb7b8b2787 100644 --- a/Zend/zend_opcode.c +++ b/Zend/zend_opcode.c @@ -295,6 +295,9 @@ int pass_two(zend_op_array *op_array TSRMLS_DC) zend_llist_apply_with_argument(&zend_extensions, (llist_apply_with_arg_func_t) zend_extension_op_array_handler, op_array TSRMLS_CC); } + op_array->opcodes = (zend_op *) erealloc(op_array->opcodes, sizeof(zend_op)*op_array->last); + op_array->size = op_array->last; + opline = op_array->opcodes; end = opline + op_array->last; while (opline < end) { @@ -306,11 +309,16 @@ int pass_two(zend_op_array *op_array TSRMLS_DC) opline->op2.u.constant.is_ref = 1; opline->op2.u.constant.refcount = 2; } + if (opline->opcode == ZEND_JMP) { + opline->op1.u.jmp_addr = &op_array->opcodes[opline->op1.u.opline_num]; + } + if (opline->opcode == ZEND_JMPZ || opline->opcode == ZEND_JMPNZ) { + opline->op2.u.jmp_addr = &op_array->opcodes[opline->op2.u.opline_num]; + } opline->handler = zend_opcode_handlers[opline->opcode]; opline++; } - op_array->opcodes = (zend_op *) erealloc(op_array->opcodes, sizeof(zend_op)*op_array->last); - op_array->size = op_array->last; + op_array->done_pass_two = 1; return 0; } |
