Hello Kyrill,

Following patch is the rebased version of v1.
(version v1) https://gcc.gnu.org/pipermail/gcc-patches/2019-November/534341.html

####

Hello,

This patch supports following MVE ACLE intrinsics with writeback.

vddupq_m_n_u8, vddupq_m_n_u32, vddupq_m_n_u16, vddupq_m_wb_u8, vddupq_m_wb_u16,
vddupq_m_wb_u32, vddupq_n_u8, vddupq_n_u32, vddupq_n_u16, vddupq_wb_u8,
vddupq_wb_u16, vddupq_wb_u32, vdwdupq_m_n_u8, vdwdupq_m_n_u32, vdwdupq_m_n_u16,
vdwdupq_m_wb_u8, vdwdupq_m_wb_u32, vdwdupq_m_wb_u16, vdwdupq_n_u8, 
vdwdupq_n_u32,
vdwdupq_n_u16, vdwdupq_wb_u8, vdwdupq_wb_u32, vdwdupq_wb_u16, vidupq_m_n_u8,
vidupq_m_n_u32, vidupq_m_n_u16, vidupq_m_wb_u8, vidupq_m_wb_u16, 
vidupq_m_wb_u32,
vidupq_n_u8, vidupq_n_u32, vidupq_n_u16, vidupq_wb_u8, vidupq_wb_u16,
vidupq_wb_u32, viwdupq_m_n_u8, viwdupq_m_n_u32, viwdupq_m_n_u16, 
viwdupq_m_wb_u8,
viwdupq_m_wb_u32, viwdupq_m_wb_u16, viwdupq_n_u8, viwdupq_n_u32, viwdupq_n_u16,
viwdupq_wb_u8, viwdupq_wb_u32, viwdupq_wb_u16.

Please refer to M-profile Vector Extension (MVE) intrinsics [1]  for more 
details.
[1] 
https://developer.arm.com/architectures/instruction-sets/simd-isas/helium/mve-intrinsics

Regression tested on arm-none-eabi and found no regressions.

Ok for trunk?

Thanks,
Srinath.

gcc/ChangeLog:

2020-03-20  Srinath Parvathaneni  <srinath.parvathan...@arm.com>
            Andre Vieira  <andre.simoesdiasvie...@arm.com>
            Mihail Ionescu  <mihail.ione...@arm.com>

        * config/arm/arm-builtins.c
        (QUINOP_UNONE_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Define quinary
        builtin qualifier.
        * config/arm/arm_mve.h (vddupq_m_n_u8): Define macro.
        (vddupq_m_n_u32): Likewise.
        (vddupq_m_n_u16): Likewise.
        (vddupq_m_wb_u8): Likewise.
        (vddupq_m_wb_u16): Likewise.
        (vddupq_m_wb_u32): Likewise.
        (vddupq_n_u8): Likewise.
        (vddupq_n_u32): Likewise.
        (vddupq_n_u16): Likewise.
        (vddupq_wb_u8): Likewise.
        (vddupq_wb_u16): Likewise.
        (vddupq_wb_u32): Likewise.
        (vdwdupq_m_n_u8): Likewise.
        (vdwdupq_m_n_u32): Likewise.
        (vdwdupq_m_n_u16): Likewise.
        (vdwdupq_m_wb_u8): Likewise.
        (vdwdupq_m_wb_u32): Likewise.
        (vdwdupq_m_wb_u16): Likewise.
        (vdwdupq_n_u8): Likewise.
        (vdwdupq_n_u32): Likewise.
        (vdwdupq_n_u16): Likewise.
        (vdwdupq_wb_u8): Likewise.
        (vdwdupq_wb_u32): Likewise.
        (vdwdupq_wb_u16): Likewise.
        (vidupq_m_n_u8): Likewise.
        (vidupq_m_n_u32): Likewise.
        (vidupq_m_n_u16): Likewise.
        (vidupq_m_wb_u8): Likewise.
        (vidupq_m_wb_u16): Likewise.
        (vidupq_m_wb_u32): Likewise.
        (vidupq_n_u8): Likewise.
        (vidupq_n_u32): Likewise.
        (vidupq_n_u16): Likewise.
        (vidupq_wb_u8): Likewise.
        (vidupq_wb_u16): Likewise.
        (vidupq_wb_u32): Likewise.
        (viwdupq_m_n_u8): Likewise.
        (viwdupq_m_n_u32): Likewise.
        (viwdupq_m_n_u16): Likewise.
        (viwdupq_m_wb_u8): Likewise.
        (viwdupq_m_wb_u32): Likewise.
        (viwdupq_m_wb_u16): Likewise.
        (viwdupq_n_u8): Likewise.
        (viwdupq_n_u32): Likewise.
        (viwdupq_n_u16): Likewise.
        (viwdupq_wb_u8): Likewise.
        (viwdupq_wb_u32): Likewise.
        (viwdupq_wb_u16): Likewise.
        (__arm_vddupq_m_n_u8): Define intrinsic.
        (__arm_vddupq_m_n_u32): Likewise.
        (__arm_vddupq_m_n_u16): Likewise.
        (__arm_vddupq_m_wb_u8): Likewise.
        (__arm_vddupq_m_wb_u16): Likewise.
        (__arm_vddupq_m_wb_u32): Likewise.
        (__arm_vddupq_n_u8): Likewise.
        (__arm_vddupq_n_u32): Likewise.
        (__arm_vddupq_n_u16): Likewise.
        (__arm_vdwdupq_m_n_u8): Likewise.
        (__arm_vdwdupq_m_n_u32): Likewise.
        (__arm_vdwdupq_m_n_u16): Likewise.
        (__arm_vdwdupq_m_wb_u8): Likewise.
        (__arm_vdwdupq_m_wb_u32): Likewise.
        (__arm_vdwdupq_m_wb_u16): Likewise.
        (__arm_vdwdupq_n_u8): Likewise.
        (__arm_vdwdupq_n_u32): Likewise.
        (__arm_vdwdupq_n_u16): Likewise.
        (__arm_vdwdupq_wb_u8): Likewise.
        (__arm_vdwdupq_wb_u32): Likewise.
        (__arm_vdwdupq_wb_u16): Likewise.
        (__arm_vidupq_m_n_u8): Likewise.
        (__arm_vidupq_m_n_u32): Likewise.
        (__arm_vidupq_m_n_u16): Likewise.
        (__arm_vidupq_n_u8): Likewise.
        (__arm_vidupq_m_wb_u8): Likewise.
        (__arm_vidupq_m_wb_u16): Likewise.
        (__arm_vidupq_m_wb_u32): Likewise.
        (__arm_vidupq_n_u32): Likewise.
        (__arm_vidupq_n_u16): Likewise.
        (__arm_vidupq_wb_u8): Likewise.
        (__arm_vidupq_wb_u16): Likewise.
        (__arm_vidupq_wb_u32): Likewise.
        (__arm_vddupq_wb_u8): Likewise.
        (__arm_vddupq_wb_u16): Likewise.
        (__arm_vddupq_wb_u32): Likewise.
        (__arm_viwdupq_m_n_u8): Likewise.
        (__arm_viwdupq_m_n_u32): Likewise.
        (__arm_viwdupq_m_n_u16): Likewise.
        (__arm_viwdupq_m_wb_u8): Likewise.
        (__arm_viwdupq_m_wb_u32): Likewise.
        (__arm_viwdupq_m_wb_u16): Likewise.
        (__arm_viwdupq_n_u8): Likewise.
        (__arm_viwdupq_n_u32): Likewise.
        (__arm_viwdupq_n_u16): Likewise.
        (__arm_viwdupq_wb_u8): Likewise.
        (__arm_viwdupq_wb_u32): Likewise.
        (__arm_viwdupq_wb_u16): Likewise.
        (vidupq_m): Define polymorphic variant.
        (vddupq_m): Likewise.
        (vidupq_u16): Likewise.
        (vidupq_u32): Likewise.
        (vidupq_u8): Likewise.
        (vddupq_u16): Likewise.
        (vddupq_u32): Likewise.
        (vddupq_u8): Likewise.
        (viwdupq_m): Likewise.
        (viwdupq_u16): Likewise.
        (viwdupq_u32): Likewise.
        (viwdupq_u8): Likewise.
        (vdwdupq_m): Likewise.
        (vdwdupq_u16): Likewise.
        (vdwdupq_u32): Likewise.
        (vdwdupq_u8): Likewise.
        * config/arm/arm_mve_builtins.def
        (QUINOP_UNONE_UNONE_UNONE_UNONE_IMM_UNONE_QUALIFIERS): Use builtin
        qualifier.
        * config/arm/mve.md (mve_vidupq_n_u<mode>): Define RTL pattern.
        (mve_vidupq_u<mode>_insn): Likewise.
        (mve_vidupq_m_n_u<mode>): Likewise.
        (mve_vidupq_m_wb_u<mode>_insn): Likewise.
        (mve_vddupq_n_u<mode>): Likewise.
        (mve_vddupq_u<mode>_insn): Likewise.
        (mve_vddupq_m_n_u<mode>): Likewise.
        (mve_vddupq_m_wb_u<mode>_insn): Likewise.
        (mve_vdwdupq_n_u<mode>): Likewise.
        (mve_vdwdupq_wb_u<mode>): Likewise.
        (mve_vdwdupq_wb_u<mode>_insn): Likewise.
        (mve_vdwdupq_m_n_u<mode>): Likewise.
        (mve_vdwdupq_m_wb_u<mode>): Likewise.
        (mve_vdwdupq_m_wb_u<mode>_insn): Likewise.
        (mve_viwdupq_n_u<mode>): Likewise.
        (mve_viwdupq_wb_u<mode>): Likewise.
        (mve_viwdupq_wb_u<mode>_insn): Likewise.
        (mve_viwdupq_m_n_u<mode>): Likewise.
        (mve_viwdupq_m_wb_u<mode>): Likewise.
        (mve_viwdupq_m_wb_u<mode>_insn): Likewise.

gcc/testsuite/ChangeLog:

2020-03-20  Srinath Parvathaneni  <srinath.parvathan...@arm.com>
            Andre Vieira  <andre.simoesdiasvie...@arm.com>
            Mihail Ionescu  <mihail.ione...@arm.com>

        * gcc.target/arm/mve/intrinsics/vddupq_m_n_u16.c: New test.
        * gcc.target/arm/mve/intrinsics/vddupq_m_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_m_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_m_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_m_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_m_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vddupq_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_m_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vdwdupq_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_m_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/vidupq_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_m_wb_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_n_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_n_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_n_u8.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_wb_u16.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_wb_u32.c: Likewise.
        * gcc.target/arm/mve/intrinsics/viwdupq_wb_u8.c: Likewise.

Attachment: rb12718.patch.gz
Description: application/gzip

Reply via email to