Skip to content

Conversation

@arnaud-lb
Copy link
Owner

@arnaud-lb arnaud-lb commented Jun 20, 2025

Based on php#6898.

With the following changes:

  • trampoline is now a user function. This avoids re-entering the VM, and allows to re-use the trampoline stack frame when calling the real function. This is similar to __call trampolines.
  • trampoline and prototype are merged into a single zend_function. This simplifies a few things and speeds up PFA creation a bit.
  • Reduced the number of new ZEND_ACC_ and ZEND_CALL_ flags since there are no free slots anymore
  • Behavior changes:
    • Partial new is not allowed
    • Updated optional/required parameter rules
    • Named placeholders are supported.

Still a WIP. There are a few things to check and cleanup.

TODO:

  • More tests
  • Address TODO comments
  • Fix reflection
  • Update callable name / ReflectionFunction::getName()
  • JIT support
  • Pipe optimization
  • Attributes (including SensitiveParameter)
  • Clone with
  • PFAs in constant expressions?
  • bind() validation (similarly to fake closures)

krakjoe and others added 7 commits June 20, 2025 19:31
Like __call trampolines, we can use an opcode-based trampoline to reduce
recursion/reentering, and reuse the call frame of the trampoline.

Also: Rebase fixes, update tests, add tests.
Comment on lines +208 to +209
/* Internal functions use an incompatible arg_info struct
* TODO: unify zend_arg_info / zend_internal_arg_info? */
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This would be nice to do, but that would require allocating zend_strings rather than using C strings which are inside the binary. Would make a lot of other stuff simpler tho.

Comment on lines 669 to 671
/* used for place holders */
#define _IS_PLACEHOLDER_ARG 20
#define _IS_PLACEHOLDER_VARIADIC 21
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Probably should be bellow _IS_NUMBER

@Crell
Copy link

Crell commented Jun 30, 2025

It looks like we still need a test for partially applying an invokable object that isn't a Closure.

$f = f(?, ?);

$f(1, 2);

Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please add a closing PHP tag in every test.

Copy link
Owner Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We should have a linter for this kind of things :)

arnaud-lb pushed a commit that referenced this pull request Aug 6, 2025
```
ext/gd/libgd/gd.c:2275:14: runtime error: signed integer overflow: 2147483647 + 1 cannot be represented in type 'int'
    #0 0x5d6a2103e1db in php_gd_gdImageCopy /home/dcarlier/Contribs/php-src/ext/gd/libgd/gd.c:2275
    #1 0x5d6a210a2b63 in gdImageCrop /home/dcarlier/Contribs/php-src/ext/gd/libgd/gd_crop.c:57
    #2 0x5d6a21018ca4 in zif_imagecrop /home/dcarlier/Contribs/php-src/ext/gd/gd.c:3575
    #3 0x5d6a21e46e7a in ZEND_DO_ICALL_SPEC_RETVAL_USED_HANDLER /home/dcarlier/Contribs/php-src/Zend/zend_vm_execute.h:1337
    #4 0x5d6a221188da in execute_ex /home/dcarlier/Contribs/php-src/Zend/zend_vm_execute.h:57246
    #5 0x5d6a221366bd in zend_execute /home/dcarlier/Contribs/php-src/Zend/zend_vm_execute.h:61634
    #6 0x5d6a21d107a6 in zend_execute_scripts /home/dcarlier/Contribs/php-src/Zend/zend.c:1895
    #7 0x5d6a21a63409 in php_execute_script /home/dcarlier/Contribs/php-src/main/main.c:2529
    #8 0x5d6a22516d5e in do_cli /home/dcarlier/Contribs/php-src/sapi/cli/php_cli.c:966
    #9 0x5d6a2251981d in main /home/dcarlier/Contribs/php-src/sapi/cli/php_cli.c:1341
    #10 0x7f10d002a3b7 in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58
    #11 0x7f10d002a47a in __libc_start_main_impl ../csu/libc-start.c:360
    #12 0x5d6a20a06da4 in _start (/home/dcarlier/Contribs/php-src/sapi/cli/php+0x2806da4) (BuildId: d9a79c7e0e4872311439d7313cb3a81fe04190a2)
```

close phpGH-18006
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants