[AArch64] Rewrite the vdup_lane intrinsics in C
Marcus Shawcroft
marcus.shawcroft@gmail.com
Tue Aug 27 09:03:00 GMT 2013
On 9 August 2013 10:48, James Greenhalgh <james.greenhalgh@arm.com> wrote:
> ---
> gcc/
>
> 2013-08-09 James Greenhalgh <james.greenhalgh@arm.com>
>
> * config/aarch64/aarch64-simd-builtins.def
> (dup_lane_scalar): Remove.
> * config/aarch64/aarch64-simd.md
> (aarch64_simd_dup): Add 'w->w' alternative.
> (aarch64_dup_lane<mode>): Allow for VALL.
> (aarch64_dup_lane_scalar<mode>): Remove.
> (aarch64_dup_lane_<vswap_width_name><mode>): New.
> (aarch64_get_lane_signed<mode>): Add w->w altenative.
> (aarch64_get_lane_unsigned<mode>): Likewise.
> (aarch64_get_lane<mode>): Likewise.
> * config/aarch64/aarch64.c (aarch64_evpc_dup): New.
> (aarch64_expand_vec_perm_const_1): Use aarch64_evpc_dup.
> * config/aarch64/iterators.md (VSWAP_WIDTH): New.
> (VCON): Change container of V2SF.
> (vswap_width_name): Likewise.
> * config/aarch64/arm_neon.h
> (__aarch64_vdup_lane_any): New.
> (__aarch64_vdup<q>_lane<q>_<fpsu><8,16,32,64>): Likewise.
> (vdup<q>_n_<psuf><8,16,32,64>): Convert to C implementation.
> (vdup<q>_lane<q>_<fpsu><8,16,32,64>): Likewise.
>
> gcc/testsuite/
>
> 2013-08-09 James Greenhalgh <james.greenhalgh@arm.com>
>
> * gcc.target/aarch64/scalar_intrinsics.c
> (vdup<bhsd>_lane<su><8,16,32,64>): Force values to SIMD registers.
OK
/Marcus
More information about the Gcc-patches
mailing list