Skip to content

Conversation

@SakiTakamachi
Copy link
Member

@SakiTakamachi SakiTakamachi commented Apr 24, 2025

For SIMD using 128-bit vectors, add a header file to use common code between SSE2 and ARM Neon.

I don't intend to replace everything with these.
The goal is to avoid having to copy a lot of "almost identical code" for non-SIMD code on ARM.

There are other places could use it, but it would involve too many changes, so I'll address that in a follow-up PR.

Copy link
Member

@dstogov dstogov left a comment

Choose a reason for hiding this comment

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

I don't have a strong opinion about this.

On one hand this enables NEON code on AArch64 almost for free.
On the other hand this requires usage of our own undocumented abstraction layer.
Most probably this layer is more limited than SSE or NEON by their selves.

Personally, I would prefer something like NEON2SSE (e.g. https://github.com/intel/ARM_NEON_2_x86_SSE)

@SakiTakamachi
Copy link
Member Author

@dstogov

Thank you for checking!

There isn’t much SIMD code in php-src yet, so for now I chose not to use any external libraries.
However, as you mentioned, using a library would provide greater flexibility, and I have absolutely no problem switching to a library if needed.

Since the SIMD code currently in php-src is based on SSE, NEON2SSE might not fit our purpose, as the direction is reversed.

We probably need something like sse2neon:
https://github.com/DLTcollab/sse2neon

Or alternatively:
https://github.com/simd-everywhere/simde

What do you think about these libraries?

@dstogov
Copy link
Member

dstogov commented Apr 28, 2025

Since the SIMD code currently in php-src is based on SSE, NEON2SSE might not fit our purpose, as the direction is reversed.

OK I didn't look too deep. Anyway, all these libraries are more complex then we really need. It may be simpler to create our own neon<-->sse wrapper that implements SSE intrinsics through NEON instructions. Similar to the API you proposed, but without introducing new "naming". This way the subset of supported SSE code should start to work on NEON out of the box.

Finally, it may be better to duplicate code with native NEON optimization instead of trying reusing SSE optimized code.

These are just my thoughts. I'm not sure what solution is the best.

@SakiTakamachi
Copy link
Member Author

@dstogov

It may be simpler to create our own neon<-->sse wrapper that implements SSE intrinsics through NEON instructions. Similar to the API you proposed, but without introducing new "naming". This way the subset of supported SSE code should start to work on NEON out of the box.

Sounds simple and good.
I’ll try to revise it based on that idea!

Finally, it may be better to duplicate code with native NEON optimization instead of trying reusing SSE optimized code.

If the differences in code due to optimization are likely to be significant, I think it’s better to write them separately.
If the differences are small, a wrapper might be sufficient.

@SakiTakamachi
Copy link
Member Author

Since bcmath had its own simd.h, I reverted those changes and modified it to use zend_simd.h instead.

As for other parts, I updated them where the current definitions in zend_simd.h are sufficient for now.

@SakiTakamachi SakiTakamachi force-pushed the zend_simd branch 3 times, most recently from d269005 to 71832dc Compare April 29, 2025 09:12
@SakiTakamachi SakiTakamachi marked this pull request as draft April 29, 2025 10:17
@SakiTakamachi SakiTakamachi force-pushed the zend_simd branch 2 times, most recently from 420c877 to 7eabd5c Compare April 29, 2025 13:58
@SakiTakamachi SakiTakamachi marked this pull request as ready for review April 29, 2025 18:27
@SakiTakamachi
Copy link
Member Author

@dstogov
How about this naming?

Zend/zend_simd.h Outdated
Comment on lines 1 to 17
/*
+----------------------------------------------------------------------+
| Zend Engine |
+----------------------------------------------------------------------+
| Copyright (c) Zend Technologies Ltd. (http://www.zend.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 2.00 of the Zend 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.zend.com/license/2_00.txt. |
| If you did not receive a copy of the Zend license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| [email protected] so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
| Authors: Saki Takamachi <[email protected]> |
+----------------------------------------------------------------------+
*/
Copy link
Member

Choose a reason for hiding this comment

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

I think it would be better to license it under BSD (there are already other files) and not give copyright to Zend Technologies.

Copy link
Member

Choose a reason for hiding this comment

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

Although copyright probably doesn't matter so I don't really mind. It's kind of the same like giving it to PHP Group. Once PHP Foundation will become legal entity, this should be much easier...

Copy link
Member

Choose a reason for hiding this comment

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

Maybe add you as a copy right holder and just change it to BSD. It would be good because it will make easier to use this file elsewhere without pulling in Zend license...

Copy link
Member

Choose a reason for hiding this comment

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

By elsewhere I mean outside php-src...

Copy link
Member

Choose a reason for hiding this comment

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

I would like to potentially pull it to jso (project that I currently use for JsonSchema development). So it might be actually even better to license it under MIT.

@SakiTakamachi SakiTakamachi marked this pull request as draft May 2, 2025 08:48
Copy link
Member

@dstogov dstogov left a comment

Choose a reason for hiding this comment

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

I think we shouldn't modify libbcmath and make it dependent on Zend includes.
The rest looks fine.

@SakiTakamachi
Copy link
Member Author

I created a library named "XSSE" under the MIT license, and I modified it to be used as zend_simd.h.
https://github.com/SakiTakamachi/xsse

@SakiTakamachi SakiTakamachi marked this pull request as ready for review May 7, 2025 10:05
@SakiTakamachi
Copy link
Member Author

OK, the code is ready for review

Copy link
Member

@dstogov dstogov left a comment

Choose a reason for hiding this comment

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

I would think about moving zend_simd.h out of Zend (it's not under Zend license) and may be renaming (as you are going to reuse this in other projects e.g. into xsse.h or emmintrin_neon.h). I would also recommend to add a short comment at start of zend_simd.h (a couple of lines e.g. a wrapper implementing <emmintrin.h> API for ARM/NEON)

I don't see any technical problems. My recommendations are optional.

@SakiTakamachi SakiTakamachi merged commit 47354a7 into php:master May 16, 2025
9 checks passed
@SakiTakamachi SakiTakamachi deleted the zend_simd branch May 16, 2025 06:42
SakiTakamachi added a commit that referenced this pull request May 27, 2025
@mvorisek mvorisek mentioned this pull request Sep 11, 2025
7 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants