php-src/Zend
Arnaud Le Blanc 17d46bb3b2
Fix oss-fuzz #71382 (#15854)
The return value of zho_build_properties_ex() is passed to ZVAL_ARR(), which sets the IS_TYPE_REFCOUNTED flag. Returning &zend_emtpy_array will crash later when trying to dtor the zval.

I'm fixing this by returning zend_new_array(0) instead of &zend_empty_array.

An alternative was to make ZVAL_ARR() aware of immutable arrays, like ZVAL_STR() is with interned strings, but I found no other problematic cases.
2024-09-17 16:06:51 +02:00
..
asm Sync Zend/*_i386_sysv_elf_gas.S with upstream (#15788) 2024-09-07 21:27:02 +02:00
Optimizer Fix GH-15821: Core dumped in Zend/Optimizer/zend_inference.c:4062 2024-09-10 16:14:03 +03:00
tests Fix oss-fuzz #71382 (#15854) 2024-09-17 16:06:51 +02:00
bench.php
LICENSE
Makefile.frag Define default RE2C_FLAGS (#14615) 2024-06-24 22:09:04 +02:00
micro_bench.php
README.md
zend_alloc_sizes.h
zend_alloc.c Zend: Add ZEND_BYTES_SWAP32/ZEND_BYTES_SWAP64 (#14910) 2024-07-22 17:57:16 +09:00
zend_alloc.h Add gc and shutdown callbacks to ZendMM custom handlers (#13432) 2024-06-19 19:43:57 +02:00
zend_API.c Fix -Wundef/C4668 warnings (#15853) 2024-09-14 11:28:32 +02:00
zend_API.h Fix registration of internal readonly child classes (#15459) 2024-08-24 12:36:54 +02:00
zend_arena.h Use zend_error_noreturn for E_ERROR consistently 2023-09-14 11:44:55 +02:00
zend_ast.c [RFC] Asymmetric visibility v2 (GH-15063) 2024-08-27 02:04:48 +02:00
zend_ast.h Drop FASTCALL on variadic functions (GH-15389) 2024-08-13 19:46:48 +02:00
zend_atomic.c Add zend_atomic_int (#14242) 2024-05-30 12:53:44 +02:00
zend_atomic.h Add zend_atomic_int (#14242) 2024-05-30 12:53:44 +02:00
zend_attributes_arginfo.h Fix registration of internal readonly child classes (#15459) 2024-08-24 12:36:54 +02:00
zend_attributes.c Fix GH-15731: Prevent #[AllowDynamicProperties] on enums (#15733) 2024-09-04 23:56:18 +01:00
zend_attributes.h RFC: Add #[\Deprecated] Attribute (#11293) 2024-07-02 09:44:25 +02:00
zend_attributes.stub.php RFC: Add #[\Deprecated] Attribute (#11293) 2024-07-02 09:44:25 +02:00
zend_bitset.h adding const attribute to trailing/leading zeros helpers. (#13861) 2024-04-02 12:10:18 +01:00
zend_build.h
zend_builtin_functions_arginfo.h Generated arginfo header files: remove empty zend_function_entry arrays (#15705) 2024-09-03 23:19:53 +02:00
zend_builtin_functions.c Lazy objects 2024-08-30 17:30:03 +02:00
zend_builtin_functions.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_builtin_functions.stub.php PHP 8.4 | Exit as function: fix incorrect parameter name (#15433) 2024-08-16 22:35:16 +01:00
zend_call_stack.c Remove unused buffer variables (#15550) 2024-08-23 16:40:19 +02:00
zend_call_stack.h Autotools: Refactor builtin checks (#14835) 2024-07-08 21:25:16 +02:00
zend_closures_arginfo.h Fix registration of internal readonly child classes (#15459) 2024-08-24 12:36:54 +02:00
zend_closures.c Include the source location in Closure names (#13550) 2024-04-12 18:21:13 +02:00
zend_closures.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_closures.stub.php
zend_compile.c Add type indicator to array/arg unpack error messages (GH-15448) 2024-09-01 22:57:12 +02:00
zend_compile.h [skip ci] zend_compile.h: ZEND_ACC_DEPRECATED can be used for class constants (#15848) 2024-09-12 17:52:43 +01:00
zend_config.w32.h Remove outdated Zend/zend_istdiostream.h file (#13765) 2024-03-21 10:37:14 +01:00
zend_constants_arginfo.h Do not generate frameless info items when func info generation is disabled 2024-02-18 11:39:00 +01:00
zend_constants.c zend_get_constant_ex() - remove commented out handling of class constants (#15728) 2024-09-04 16:15:27 +02:00
zend_constants.h Implement reflection constant 2024-04-17 22:53:09 +02:00
zend_constants.stub.php Improve detection of predefined constants 2023-09-07 10:00:55 +02:00
zend_cpuinfo.c Fix GH-15292: Dynamic AVX detection is broken for MSVC 2024-08-09 18:11:46 +02:00
zend_cpuinfo.h hash: Add SHA-NI implementation of SHA-256 (#15152) 2024-08-08 22:19:33 +02:00
zend_default_classes.c
zend_dtrace.c
zend_dtrace.d
zend_dtrace.h
zend_enum_arginfo.h Implement "support doc comments for internal classes and functions" (#13266) 2024-02-25 08:41:31 +01:00
zend_enum.c zend_enum.c: make a bunch of pointers const (#15932) 2024-09-17 12:57:01 +02:00
zend_enum.h zend_enum.c: make a bunch of pointers const (#15932) 2024-09-17 12:57:01 +02:00
zend_enum.stub.php
zend_errors.h
zend_exceptions_arginfo.h Generated arginfo header files: remove empty zend_function_entry arrays (#15705) 2024-09-03 23:19:53 +02:00
zend_exceptions.c Fix some misleading comments about __clone() never being executed (#15926) 2024-09-17 01:53:30 +02:00
zend_exceptions.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_exceptions.stub.php Add request_parse_body() function 2024-02-08 12:08:07 +01:00
zend_execute_API.c Lazy objects 2024-08-30 17:30:03 +02:00
zend_execute.c Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_execute.h Interrupt while internal frame is on the stack (#14627) 2024-09-05 00:35:55 +02:00
zend_extensions.c Make internal run_time_cache a persistent allocation (#15040) 2024-09-07 01:45:26 +02:00
zend_extensions.h Make internal run_time_cache a persistent allocation (#15040) 2024-09-07 01:45:26 +02:00
zend_fibers_arginfo.h Fix registration of internal readonly child classes (#15459) 2024-08-24 12:36:54 +02:00
zend_fibers.c Merge branch 'PHP-8.3' 2024-08-28 17:45:49 +02:00
zend_fibers.h Allow fiber switching during destructor execution 2024-07-02 15:00:40 +02:00
zend_fibers.stub.php
zend_float.c
zend_float.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_frameless_function.c Implement stackless internal function calls 2024-02-06 17:42:28 +01:00
zend_frameless_function.h Optimize observers (#13649) 2024-06-15 14:42:27 +02:00
zend_gc.c Allow fiber switching during destructor execution 2024-07-02 15:00:40 +02:00
zend_gc.h Allow fiber switching during destructor execution 2024-07-02 15:00:40 +02:00
zend_gdb.c Zend: change uses of sprintf into snprintf 2024-06-14 08:12:03 -07:00
zend_gdb.h
zend_generators_arginfo.h Generated arginfo header files: remove empty zend_function_entry arrays (#15705) 2024-09-03 23:19:53 +02:00
zend_generators.c Merge branch 'PHP-8.3' 2024-08-28 17:45:49 +02:00
zend_generators.h Merge branch 'PHP-8.3' 2024-08-28 17:45:49 +02:00
zend_generators.stub.php Make ReflectionGenerator::getFunction() legal after generator termination (#14167) 2024-05-21 08:54:51 +02:00
zend_globals_macros.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_globals.h Make internal run_time_cache a persistent allocation (#15040) 2024-09-07 01:45:26 +02:00
zend_hash.c Throw error for recursive comparison, instead of fatal (#14989) 2024-07-22 15:53:41 +02:00
zend_hash.h Add zend_hash_get_current_pos_ex() (#14770) 2024-07-02 19:11:41 +02:00
zend_highlight.c [RFC] Property hooks (#13455) 2024-07-14 11:55:03 +02:00
zend_highlight.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_hrtime.c Use ZEND_API in zend_hrtime (#13288) 2024-03-17 03:09:08 +01:00
zend_hrtime.h Use ZEND_API in zend_hrtime (#13288) 2024-03-17 03:09:08 +01:00
zend_inheritance.c zend_inheritance.c: make a bunch of pointers const (GH-15934) 2024-09-17 12:44:17 +02:00
zend_inheritance.h [RFC] Property hooks (#13455) 2024-07-14 11:55:03 +02:00
zend_ini_parser.y Merge branch 'PHP-8.3' 2024-06-28 22:10:23 +02:00
zend_ini_scanner.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_ini_scanner.l small fixes 2023-07-18 08:31:02 +01:00
zend_ini.c Merge branch 'PHP-8.3' 2024-07-19 14:59:57 +02:00
zend_ini.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_interfaces_arginfo.h Generated arginfo header files: remove empty zend_function_entry arrays (#15705) 2024-09-03 23:19:53 +02:00
zend_interfaces.c [RFC] Property hooks (#13455) 2024-07-14 11:55:03 +02:00
zend_interfaces.h
zend_interfaces.stub.php
zend_iterators.c
zend_iterators.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_language_parser.y [RFC] Asymmetric visibility v2 (GH-15063) 2024-08-27 02:04:48 +02:00
zend_language_scanner.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_language_scanner.l [RFC] Asymmetric visibility v2 (GH-15063) 2024-08-27 02:04:48 +02:00
zend_lazy_objects.c Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_lazy_objects.h Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_list.c Merge branch 'PHP-8.1' into PHP-8.2 2023-10-29 21:47:23 +01:00
zend_list.h Fix -Wenum-int-mismatch warnings on gcc 13 2023-04-20 16:04:59 +02:00
zend_llist.c
zend_llist.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_long.h
zend_map_ptr.h Make internal run_time_cache a persistent allocation (#15040) 2024-09-07 01:45:26 +02:00
zend_max_execution_timer.c Revert "Merge branch 'PHP-8.3'" 2024-08-20 16:34:52 +02:00
zend_max_execution_timer.h
zend_mmap.h
zend_modules.h Merge branch 'PHP-8.3' 2024-02-20 21:26:39 +01:00
zend_multibyte.c general signatures discrepencies fixes (#13122) 2024-01-10 22:19:23 +00:00
zend_multibyte.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_multiply.h Autotools: Refactor builtin checks (#14835) 2024-07-08 21:25:16 +02:00
zend_object_handlers.c Fix ReflectionProperty::isInitialized() for hooked props 2024-09-10 14:46:16 +02:00
zend_object_handlers.h Lazy objects 2024-08-30 17:30:03 +02:00
zend_objects_API.c Allow fiber switching during destructor execution 2024-07-02 15:00:40 +02:00
zend_objects_API.h Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_objects.c Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_objects.h Lazy objects 2024-08-30 17:30:03 +02:00
zend_observer.c Optimize observers (#13649) 2024-06-15 14:42:27 +02:00
zend_observer.h Optimize observers (#13649) 2024-06-15 14:42:27 +02:00
zend_opcode.c [RFC] Property hooks (#13455) 2024-07-14 11:55:03 +02:00
zend_operators.c Lazy objects 2024-08-30 17:30:03 +02:00
zend_operators.h Autotools: Refactor builtin checks (#14835) 2024-07-08 21:25:16 +02:00
zend_portability.h Fix ZEND_FASTCALL definition wrt. x64 Windows clang builds (GH-15425) 2024-08-18 12:20:09 +02:00
zend_property_hooks.c Fix oss-fuzz #71382 (#15854) 2024-09-17 16:06:51 +02:00
zend_property_hooks.h [RFC] Property hooks (#13455) 2024-07-14 11:55:03 +02:00
zend_ptr_stack.c
zend_ptr_stack.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_range_check.h
zend_signal.c Mark multple functions as static (#13864) 2024-05-22 13:11:46 +02:00
zend_signal.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_smart_str_public.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_smart_str.c Show enum cases in errors 2024-06-10 22:58:25 +02:00
zend_smart_str.h Show enum cases in errors 2024-06-10 22:58:25 +02:00
zend_smart_string_public.h
zend_smart_string.h
zend_sort.c
zend_sort.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_stack.c
zend_stack.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_stream.c
zend_stream.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_string.c Merge branch 'PHP-8.2' into PHP-8.3 2024-09-09 16:45:54 +02:00
zend_string.h Rename ZEND_STR_DEPRECATED to ZEND_STR_DEPRECATED_CAPITALIZED (#15831) 2024-09-10 22:45:23 +01:00
zend_strtod_int.h Add comments about internal headers (GH-15689) 2024-09-08 16:11:25 +02:00
zend_strtod.c Merge branch 'PHP-8.3' 2024-09-11 21:20:14 +01:00
zend_strtod.h Remove zend_strtod mutex (#13974) 2024-04-23 11:52:38 +02:00
zend_system_id.c Interrupt while internal frame is on the stack (#14627) 2024-09-05 00:35:55 +02:00
zend_system_id.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_type_info.h Backport fix for HASH/PACKED array inference through MAY_BE_ARRAY_EMPTY flag (#12591) 2023-11-03 10:54:57 +03:00
zend_types.h Lazy objects 2024-08-30 17:30:03 +02:00
zend_variables.c
zend_variables.h Zend: Remove dependency on zend.h for certain headers (#12166) 2023-09-11 12:27:21 +01:00
zend_verify_type_inference.h [skip ci] Use _exit for type inference verification 2024-01-23 18:15:30 +01:00
zend_virtual_cwd.c Zend: Voidify virtual_cwd_(de)activate() (#15554) 2024-08-23 15:28:37 +01:00
zend_virtual_cwd.h Zend: Voidify virtual_cwd_(de)activate() (#15554) 2024-08-23 15:28:37 +01:00
zend_vm_def.h Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_vm_execute.h Fix zend_get_property_info_for_slot() for lazy objects (#15855) 2024-09-16 16:58:12 +02:00
zend_vm_execute.skl Fixed GH-12596: Segmentation fault on AArch64 release build with opcache.jit=1112 (#12813) 2023-12-05 12:04:00 +03:00
zend_vm_gen.php Optimize observers (#13649) 2024-06-15 14:42:27 +02:00
zend_vm_handlers.h [RFC] Convert exit (and die) from language constructs to functions (#13483) 2024-08-14 12:44:12 +01:00
zend_vm_opcodes.c [RFC] Convert exit (and die) from language constructs to functions (#13483) 2024-08-14 12:44:12 +01:00
zend_vm_opcodes.h [RFC] Convert exit (and die) from language constructs to functions (#13483) 2024-08-14 12:44:12 +01:00
zend_vm_trace_handlers.h
zend_vm_trace_lines.h
zend_vm_trace_map.h
zend_vm.h Fix header errors when parsed standalone (#14272) 2024-05-20 22:30:38 +02:00
zend_weakrefs_arginfo.h Fix registration of internal readonly child classes (#15459) 2024-08-24 12:36:54 +02:00
zend_weakrefs.c Use RETURN_THROWS() for WeakMap methods 2024-06-18 22:34:18 +02:00
zend_weakrefs.h Remove WeakMap entries whose key is only reachable through the entry value (#10932) 2023-07-16 13:39:08 +02:00
zend_weakrefs.stub.php
zend.c Merge branch 'PHP-8.3' 2024-09-09 19:35:09 +02:00
zend.h PHP-8.2 is now for PHP 8.2.25-dev 2024-09-10 15:26:28 -04:00
Zend.m4 Fix Solaris 10 build: missing libproc.h (#15525) 2024-08-22 20:26:44 +02:00

Zend Engine

Zend memory manager

General

The goal of the new memory manager (available since PHP 5.2) is to reduce memory allocation overhead and speedup memory management.

Debugging

Normal:

sapi/cli/php -r 'leak();'

Zend MM disabled:

USE_ZEND_ALLOC=0 valgrind --leak-check=full sapi/cli/php -r 'leak();'

Shared extensions

Since PHP 5.3.11 it is possible to prevent shared extensions from unloading so that valgrind can correctly track the memory leaks in shared extensions. For this there is the ZEND_DONT_UNLOAD_MODULES environment variable. If set, then DL_UNLOAD() is skipped during the shutdown of shared extensions.

ZEND_VM

ZEND_VM architecture allows specializing opcode handlers according to op_type fields and using different execution methods (call threading, switch threading and direct threading). As a result ZE2 got more than 20% speedup on raw PHP code execution (with specialized executor and direct threading execution method). As in most PHP applications raw execution speed isn't the limiting factor but system calls and database calls are, your mileage with this patch will vary.

Most parts of the old zend_execute.c go into zend_vm_def.h. Here you can find opcode handlers and helpers. The typical opcode handler template looks like this:

ZEND_VM_HANDLER(<OPCODE-NUMBER>, <OPCODE>, <OP1_TYPES>, <OP2_TYPES>)
{
    <HANDLER'S CODE>
}

<OPCODE-NUMBER> is a opcode number (0, 1, ...) <OPCODE> is an opcode name (ZEN_NOP, ZEND_ADD, :) <OP1_TYPES> and <OP2_TYPES> are masks for allowed operand op_types. Specializer will generate code only for defined combination of types. You can use any combination of the following op_types UNUSED, CONST, VAR, TMP and CV also you can use ANY mask to disable specialization according operand's op_type. <HANDLER'S CODE> is a handler's code itself. For most handlers it stills the same as in old zend_execute.c, but now it uses macros to access opcode operands and some internal executor data.

You can see the conformity of new macros to old code in the following list:

EXECUTE_DATA
    execute_data
ZEND_VM_DISPATCH_TO_HANDLER(<OP>)
    return <OP>_helper(ZEND_OPCODE_HANDLER_ARGS_PASSTHRU)
ZEND_VM_DISPATCH_TO_HELPER(<NAME>)
    return <NAME>(ZEND_OPCODE_HANDLER_ARGS_PASSTHRU)
ZEND_VM_DISPATCH_TO_HELPER_EX(<NAME>,<PARAM>,<VAL>)
    return <NAME>(<VAL>, ZEND_OPCODE_HANDLER_ARGS_PASSTHRU)
ZEND_VM_CONTINUE()
    return 0
ZEND_VM_NEXT_OPCODE()
    NEXT_OPCODE()
ZEND_VM_SET_OPCODE(<TARGET>
    SET_OPCODE(<TARGET>
ZEND_VM_INC_OPCODE()
    INC_OPCOD()
ZEND_VM_RETURN_FROM_EXECUTE_LOOP()
    RETURN_FROM_EXECUTE_LOOP()
ZEND_VM_C_LABEL(<LABEL>):
    <LABEL>:
ZEND_VM_C_GOTO(<LABEL>)
    goto <LABEL>
OP<X>_TYPE
    opline->op<X>.op_type
GET_OP<X>_ZVAL_PTR(<TYPE>)
    get_zval_ptr(&opline->op<X>, EX(Ts), &free_op<X>, <TYPE>)
GET_OP<X>_ZVAL_PTR_PTR(<TYPE>)
    get_zval_ptr_ptr(&opline->op<X>, EX(Ts), &free_op<X>, <TYPE>)
GET_OP<X>_OBJ_ZVAL_PTR(<TYPE>)
    get_obj_zval_ptr(&opline->op<X>, EX(Ts), &free_op<X>, <TYPE>)
GET_OP<X>_OBJ_ZVAL_PTR_PTR(<TYPE>)
    get_obj_zval_ptr_ptr(&opline->op<X>, EX(Ts), &free_op<X>, <TYPE>)
IS_OP<X>_TMP_FREE()
    IS_TMP_FREE(free_op<X>)
FREE_OP<X>()
    FREE_OP(free_op<X>)
FREE_OP<X>_IF_VAR()
    FREE_VAR(free_op<X>)
FREE_OP<X>_VAR_PTR()
    FREE_VAR_PTR(free_op<X>)

Executor's helpers can be defined without parameters or with one parameter. This is done with the following constructs:

ZEND_VM_HELPER(<HELPER-NAME>, <OP1_TYPES>, <OP2_TYPES>)
{
    <HELPER'S CODE>
}

ZEND_VM_HELPER_EX(<HELPER-NAME>, <OP1_TYPES>, <OP2_TYPES>, <PARAM_SPEC>)
{
    <HELPER'S CODE>
}

The executors code is generated by the PHP script zend_vm_gen.php. It uses zend_vm_def.h and zend_vm_execute.skl as input and produces zend_vm_opcodes.h and zend_vm_execute.h. The first file is a list of opcode definitions. It is included from zend_compile.h. The second one is an executor code itself. It is included from zend_execute.c.

zend_vm_gen.php can produce different kind of executors. You can select a different opcode threading model using --with-vm-kind=CALL|SWITCH|GOTO|HYBRID. You can disable opcode specialization using --without-specializer. At last you can debug the executor using the original zend_vm_def.h or the generated zend_vm_execute.h file. Debugging with the original file requires the --with-lines option. By default, Zend Engine uses the following command to generate the executor:

# Default VM kind is HYBRID
php zend_vm_gen.php --with-vm-kind=HYBRID