diff options
author | Ricardo Jesus <rjj@nvidia.com> | 2024-10-14 14:28:02 +0100 |
---|---|---|
committer | Jonathan Wakely <redi@gcc.gnu.org> | 2024-10-24 15:01:23 +0100 |
commit | cc33531df065c20a52cb0c35637f096978128b46 (patch) | |
tree | 68315f262046581e145f78edc258275e6ae98e27 /gcc/fortran/misc.cc | |
parent | b02503d3fe79778ccc149b0abbc736f7972603da (diff) | |
download | gcc-cc33531df065c20a52cb0c35637f096978128b46.zip gcc-cc33531df065c20a52cb0c35637f096978128b46.tar.gz gcc-cc33531df065c20a52cb0c35637f096978128b46.tar.bz2 |
aarch64: libstdc++: Use shufflevector instead of shuffle in opt_random.h
This patch modifies the implementation of the vectorized mersenne
twister random number generator to use __builtin_shufflevector instead
of __builtin_shuffle. This makes it (almost) compatible with Clang.
To make the implementation fully compatible with Clang, Clang will need
to support internal Neon types like __Uint8x16_t and __Uint32x4_t, which
currently it does not. This looks like an oversight in Clang and so will
be addressed separately.
I see no codegen change with this patch.
Bootstrapped and tested on aarch64-none-linux-gnu.
libstdc++-v3/ChangeLog:
* config/cpu/aarch64/opt/ext/opt_random.h (__VEXT): Replace uses
of __builtin_shuffle with __builtin_shufflevector.
(__aarch64_lsl_128): Move shift amount to a template parameter.
(__aarch64_lsr_128): Move shift amount to a template parameter.
(__aarch64_recursion): Update call sites of __aarch64_lsl_128
and __aarch64_lsr_128.
Signed-off-by: Ricardo Jesus <rjj@nvidia.com>
Diffstat (limited to 'gcc/fortran/misc.cc')
0 files changed, 0 insertions, 0 deletions