-
Notifications
You must be signed in to change notification settings - Fork 8k
Zend: fix undefined symbol 'execute_ex' on Windows ARM64 Issue#19064 #19068
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
ext/gd: fix emmintrin.h not found on Windows ARM64
Nice catch ! we do not have windows arm64 CI. @cmb69 does it look good to you ? |
This looks generally good to me, but zend_vm_execute.h needs to be regenerated since zend_vm_execute.h has been changed (see zend_vm_gen.php). I'm not quite sure what to do about gd_interpolation.c; upstream doesn't have these lines, and I think they are superfluous; but it doesn't hurt to apply this patch for now. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
VM change is fine in any case
ext/gd/libgd/gd_interpolation.c
Outdated
#include "gd_intern.h" | ||
|
||
#ifdef _MSC_VER | ||
#if defined(_MSC_VER) && (defined(_M_IX86) || defined(_M_X64)) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We have a matching pragma optimize down below.
Probably, the include should just be dropped?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The upstream libgd has removed these lines, it might be safe to remove them?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Indeed: libgd/libgd@f1480ab
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, I removed them.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you!
The pragma optimize at the bottom of the file is now likely also useless; however, upstream also has this and we'd like to be as close to upstream as reasonably possible, so whatever. This is good. |
* PHP-8.4: Update NEWS for GH-19068 ext/gd: Drop useless and doubtful MSVC specific code (libgd/libgd@f1480ab) Zend: fix undefined symbol 'execute_ex' on Windows ARM64 #19064; ext/gd: fix emmintrin.h not found on Windows ARM64
Merged, thanks! |
I'll cherry-pick your gd change into 8.3 as well. |
ext/gd: fix emmintrin.h not found on Windows ARM64. emmintrin.h is x86 specific.