mirror of
https://github.com/php/php-src.git
synced 2025-08-16 14:08:47 +02:00

From an engine perspective, named parameters mainly add three concepts: * The SEND_* opcodes now accept a CONST op2, which is the argument name. For now, it is looked up by linear scan and runtime cached. * This may leave UNDEF arguments on the stack. To avoid having to deal with them in other places, a CHECK_UNDEF_ARGS opcode is used to either replace them with defaults, or error. * For variadic functions, EX(extra_named_params) are collected and need to be freed based on ZEND_CALL_HAS_EXTRA_NAMED_PARAMS. RFC: https://wiki.php.net/rfc/named_params Closes GH-5357.
69 lines
3 KiB
C
69 lines
3 KiB
C
/*
|
|
+----------------------------------------------------------------------+
|
|
| Zend Engine, Call Graph |
|
|
+----------------------------------------------------------------------+
|
|
| Copyright (c) The PHP Group |
|
|
+----------------------------------------------------------------------+
|
|
| This source file is subject to version 3.01 of the PHP license, |
|
|
| that is bundled with this package in the file LICENSE, and is |
|
|
| available through the world-wide-web at the following url: |
|
|
| http://www.php.net/license/3_01.txt |
|
|
| If you did not receive a copy of the PHP license and are unable to |
|
|
| obtain it through the world-wide-web, please send a note to |
|
|
| license@php.net so we can mail you a copy immediately. |
|
|
+----------------------------------------------------------------------+
|
|
| Authors: Dmitry Stogov <dmitry@php.net> |
|
|
+----------------------------------------------------------------------+
|
|
*/
|
|
|
|
#ifndef ZEND_CALL_GRAPH_H
|
|
#define ZEND_CALL_GRAPH_H
|
|
|
|
#include "zend_ssa.h"
|
|
#include "zend_func_info.h"
|
|
#include "zend_optimizer.h"
|
|
|
|
typedef struct _zend_send_arg_info {
|
|
zend_op *opline;
|
|
} zend_send_arg_info;
|
|
|
|
struct _zend_call_info {
|
|
zend_op_array *caller_op_array;
|
|
zend_op *caller_init_opline;
|
|
zend_op *caller_call_opline;
|
|
zend_function *callee_func;
|
|
zend_call_info *next_caller;
|
|
zend_call_info *next_callee;
|
|
zend_bool recursive;
|
|
zend_bool send_unpack; /* Parameters passed by SEND_UNPACK or SEND_ARRAY */
|
|
zend_bool named_args; /* Function has named arguments */
|
|
int num_args;
|
|
zend_send_arg_info arg_info[1];
|
|
};
|
|
|
|
struct _zend_func_info {
|
|
int num;
|
|
uint32_t flags;
|
|
zend_ssa ssa; /* Static Single Assignmnt Form */
|
|
zend_call_info *caller_info; /* where this function is called from */
|
|
zend_call_info *callee_info; /* which functions are called from this one */
|
|
zend_call_info **call_map; /* Call info associated with init/call/send opnum */
|
|
zend_ssa_var_info return_info;
|
|
};
|
|
|
|
typedef struct _zend_call_graph {
|
|
int op_arrays_count;
|
|
zend_op_array **op_arrays;
|
|
zend_func_info *func_infos;
|
|
} zend_call_graph;
|
|
|
|
BEGIN_EXTERN_C()
|
|
|
|
int zend_build_call_graph(zend_arena **arena, zend_script *script, zend_call_graph *call_graph);
|
|
void zend_analyze_call_graph(zend_arena **arena, zend_script *script, zend_call_graph *call_graph);
|
|
zend_call_info **zend_build_call_map(zend_arena **arena, zend_func_info *info, const zend_op_array *op_array);
|
|
int zend_analyze_calls(zend_arena **arena, zend_script *script, uint32_t build_flags, zend_op_array *op_array, zend_func_info *func_info);
|
|
|
|
END_EXTERN_C()
|
|
|
|
#endif /* ZEND_CALL_GRAPH_H */
|