You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When building with MSVC (or clang-cl), ZEND_FASTCALL is defined as __vectorcall. While __vectorcall is similar to the default x64 calling convention, and __fastcall on x86, respectively, there are notable differences. It seems to me that our JIT does not cater to these. That may still not be relevant to core functions, but could be an issue with external extensions which declare function as ZEND_FASTCALL.
Furthermore, there is definitely an issue regarding portability, since GCC doesn't support __vectorcall at all. While we do not necessarily support GCC on Windows, compatibility still seems to be a good thing.
On x86-32 targets, the fastcall attribute causes the compiler to pass the first argument (if of integral type) in the register ECX and the second argument (if of integral type) in the register EDX. Subsequent and other typed arguments are passed on the stack.
The first two DWORD or smaller arguments that are found in the argument list from left to right are passed in ECX and EDX registers; all other arguments are passed on the stack from right to left.
This is possibly just a documentation issue (I haven't checked).
Anyhow, I suggest to change ZEND_FASTCALL with MSVC to use the default x64 calling convention for the x64 ABI; not sure what to suggest regarding x86.
Note that even __fastcall appears to be slightly different to the Windows __fastcall convention:
[...]
This is possibly just a documentation issue (I haven't checked).
Anyhow, I suggest to change ZEND_FASTCALL with MSVC to use the default x64 calling convention for the x64 ABI; not sure what to suggest regarding x86.
This seems sensible to me. The alternative is to add __vectorcall support to IR and to the the frontend, but I'm not sure this is worth it.
For x86, the frontend already tells IR to use the fastcall convention when needed, so we should probably switch to fastcall on x86/Windows. I'm not sure whether IR is consistent with either GCC or MSVC, but I think it would make sense if IR added full compatibility with both.
Description
When building with MSVC (or clang-cl),
ZEND_FASTCALL
is defined as__vectorcall
. While__vectorcall
is similar to the default x64 calling convention, and__fastcall
on x86, respectively, there are notable differences. It seems to me that our JIT does not cater to these. That may still not be relevant to core functions, but could be an issue with external extensions which declare function asZEND_FASTCALL
.Furthermore, there is definitely an issue regarding portability, since GCC doesn't support
__vectorcall
at all. While we do not necessarily support GCC on Windows, compatibility still seems to be a good thing.Note that even
__fastcall
appears to be slightly different to the Windows__fastcall
convention:This is possibly just a documentation issue (I haven't checked).
Anyhow, I suggest to change
ZEND_FASTCALL
with MSVC to use the default x64 calling convention for the x64 ABI; not sure what to suggest regarding x86.cc @dstogov, @nielsdos, @arnaud-lb
PHP Version
PHP 8.4 (likely older)
Operating System
Windows
The text was updated successfully, but these errors were encountered: