LGTM

Juzhe-Zhong <juzhe.zh...@rivai.ai> 於 2023年8月11日 週五 17:56 寫道:

> This patch enables COSNT_VECTOR for VLS modes.
>
> void foo1 (int * __restrict a)
> {
>     for (int i = 0; i < 16; i++)
>       a[i] = 8;
> }
>
> void foo2 (int * __restrict a)
> {
>     for (int i = 0; i < 16; i++)
>       a[i] = i;
> }
>
> Compile option: -O3 --param=riscv-autovec-preference=scalable
>
> Before this patch:
>
> foo1:
>         lui     a5,%hi(.LC0)
>         addi    a5,a5,%lo(.LC0)
>         vsetivli        zero,4,e32,m1,ta,ma
>         addi    a4,a0,16
>         vle32.v v1,0(a5)
>         vse32.v v1,0(a0)
>         vse32.v v1,0(a4)
>         addi    a4,a0,32
>         vse32.v v1,0(a4)
>         addi    a0,a0,48
>         vse32.v v1,0(a0)
>         ret
> foo2:
>         lui     a5,%hi(.LC1)
>         addi    a5,a5,%lo(.LC1)
>         vsetivli        zero,4,e32,m1,ta,ma
>         vle32.v v1,0(a5)
>         lui     a5,%hi(.LC2)
>         addi    a5,a5,%lo(.LC2)
>         vse32.v v1,0(a0)
>         vle32.v v1,0(a5)
>         lui     a5,%hi(.LC3)
>         addi    a4,a0,16
>         addi    a5,a5,%lo(.LC3)
>         vse32.v v1,0(a4)
>         vle32.v v1,0(a5)
>         addi    a4,a0,32
>         lui     a5,%hi(.LC4)
>         vse32.v v1,0(a4)
>         addi    a0,a0,48
>         addi    a5,a5,%lo(.LC4)
>         vle32.v v1,0(a5)
>         vse32.v v1,0(a0)
>         ret
>
> After this patch:
>
> foo1:
>         vsetivli        zero,16,e32,mf2,ta,ma
>         vmv.v.i v1,8
>         vse32.v v1,0(a0)
>         ret
>         .size   foo1, .-foo1
>         .align  1
>         .globl  foo2
>         .type   foo2, @function
> foo2:
>         vsetivli        zero,16,e32,mf2,ta,ma
>         vid.v   v1
>         vse32.v v1,0(a0)
>         ret
>
> gcc/ChangeLog:
>
>         * config/riscv/autovec.md: Add VLS CONST_VECTOR.
>         * config/riscv/riscv.cc (riscv_const_insns): Ditto.
>         * config/riscv/vector.md: Ditto.
>
> gcc/testsuite/ChangeLog:
>
>         * gcc.target/riscv/rvv/autovec/vls/def.h: Add VLS CONST_VECTOR
> tests.
>         * gcc.target/riscv/rvv/autovec/vls/const-1.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/const-2.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/const-3.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/const-4.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/const-5.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/series-1.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/series-2.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/series-3.c: New test.
>         * gcc.target/riscv/rvv/autovec/vls/series-4.c: New test.
>
> ---
>  gcc/config/riscv/autovec.md                   |  2 +-
>  gcc/config/riscv/riscv.cc                     |  2 +-
>  gcc/config/riscv/vector.md                    |  8 ++--
>  .../riscv/rvv/autovec/vls/const-1.c           | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/const-2.c           | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/const-3.c           | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/const-4.c           | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/const-5.c           | 40 +++++++++++++++++++
>  .../gcc.target/riscv/rvv/autovec/vls/def.h    | 14 +++++++
>  .../riscv/rvv/autovec/vls/series-1.c          | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/series-2.c          | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/series-3.c          | 40 +++++++++++++++++++
>  .../riscv/rvv/autovec/vls/series-4.c          | 40 +++++++++++++++++++
>  13 files changed, 380 insertions(+), 6 deletions(-)
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-1.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-2.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-3.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-4.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-5.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-1.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-2.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-3.c
>  create mode 100644
> gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-4.c
>
> diff --git a/gcc/config/riscv/autovec.md b/gcc/config/riscv/autovec.md
> index 3b396a9a990..cf4efbae44f 100644
> --- a/gcc/config/riscv/autovec.md
> +++ b/gcc/config/riscv/autovec.md
> @@ -318,7 +318,7 @@
>  ;;
> -------------------------------------------------------------------------
>
>  (define_expand "@vec_series<mode>"
> -  [(match_operand:VI 0 "register_operand")
> +  [(match_operand:V_VLSI 0 "register_operand")
>     (match_operand:<VEL> 1 "reg_or_int_operand")
>     (match_operand:<VEL> 2 "reg_or_int_operand")]
>    "TARGET_VECTOR"
> diff --git a/gcc/config/riscv/riscv.cc b/gcc/config/riscv/riscv.cc
> index 5dc19ecd377..f9b7a9ee749 100644
> --- a/gcc/config/riscv/riscv.cc
> +++ b/gcc/config/riscv/riscv.cc
> @@ -1336,7 +1336,7 @@ riscv_const_insns (rtx x)
>                out range of [-16, 15].
>           - 3. const series vector.
>           ...etc.  */
> -       if (riscv_v_ext_vector_mode_p (GET_MODE (x)))
> +       if (riscv_v_ext_mode_p (GET_MODE (x)))
>           {
>             /* const series vector.  */
>             rtx base, step;
> diff --git a/gcc/config/riscv/vector.md b/gcc/config/riscv/vector.md
> index cf37b472930..2550fc9a630 100644
> --- a/gcc/config/riscv/vector.md
> +++ b/gcc/config/riscv/vector.md
> @@ -5956,8 +5956,8 @@
>     (set_attr "mode" "<MODE>")])
>
>  (define_insn "@pred_series<mode>"
> -  [(set (match_operand:VI 0 "register_operand"           "=vd, vd, vr,
> vr")
> -       (if_then_else:VI
> +  [(set (match_operand:V_VLSI 0 "register_operand"           "=vd, vd,
> vr, vr")
> +       (if_then_else:V_VLSI
>           (unspec:<VM>
>             [(match_operand:<VM> 1 "vector_mask_operand" " vm, vm,Wc1,Wc1")
>              (match_operand 3 "vector_length_operand"    " rK, rK, rK, rK")
> @@ -5966,8 +5966,8 @@
>              (match_operand 6 "const_int_operand"        "  i,  i,  i,  i")
>              (reg:SI VL_REGNUM)
>              (reg:SI VTYPE_REGNUM)] UNSPEC_VPREDICATE)
> -         (vec_series:VI (const_int 0) (const_int 1))
> -         (match_operand:VI 2 "vector_merge_operand"     " vu,  0, vu,
> 0")))]
> +         (vec_series:V_VLSI (const_int 0) (const_int 1))
> +         (match_operand:V_VLSI 2 "vector_merge_operand"     " vu,  0,
> vu,  0")))]
>    "TARGET_VECTOR"
>    "vid.v\t%0%p1"
>    [(set_attr "type" "vmidx")
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-1.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-1.c
> new file mode 100644
> index 00000000000..f3217e6063e
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-1.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_CONST (int16_t, -16, 2)
> +DEF_CONST (int16_t, -16, 4)
> +DEF_CONST (int16_t, -16, 8)
> +DEF_CONST (int16_t, -16, 16)
> +DEF_CONST (int16_t, -16, 32)
> +DEF_CONST (int16_t, -16, 64)
> +DEF_CONST (int16_t, -16, 128)
> +DEF_CONST (int16_t, -16, 256)
> +DEF_CONST (int16_t, -16, 512)
> +DEF_CONST (int16_t, -16, 1024)
> +DEF_CONST (int16_t, -16, 2048)
> +
> +DEF_CONST (int32_t, -16, 2)
> +DEF_CONST (int32_t, -16, 4)
> +DEF_CONST (int32_t, -16, 8)
> +DEF_CONST (int32_t, -16, 16)
> +DEF_CONST (int32_t, -16, 32)
> +DEF_CONST (int32_t, -16, 64)
> +DEF_CONST (int32_t, -16, 128)
> +DEF_CONST (int32_t, -16, 256)
> +DEF_CONST (int32_t, -16, 512)
> +DEF_CONST (int32_t, -16, 1024)
> +
> +DEF_CONST (int64_t, -16, 2)
> +DEF_CONST (int64_t, -16, 4)
> +DEF_CONST (int64_t, -16, 8)
> +DEF_CONST (int64_t, -16, 16)
> +DEF_CONST (int64_t, -16, 32)
> +DEF_CONST (int64_t, -16, 64)
> +DEF_CONST (int64_t, -16, 128)
> +DEF_CONST (int64_t, -16, 256)
> +DEF_CONST (int64_t, -16, 512)
> +
> +/* { dg-final { scan-assembler-times {vmv\.v\.i\s+v[0-9]+,\s*-16} 30 } }
> */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-2.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-2.c
> new file mode 100644
> index 00000000000..99255ec5aa6
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-2.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_CONST (int16_t, 15, 2)
> +DEF_CONST (int16_t, 15, 4)
> +DEF_CONST (int16_t, 15, 8)
> +DEF_CONST (int16_t, 15, 16)
> +DEF_CONST (int16_t, 15, 32)
> +DEF_CONST (int16_t, 15, 64)
> +DEF_CONST (int16_t, 15, 128)
> +DEF_CONST (int16_t, 15, 256)
> +DEF_CONST (int16_t, 15, 512)
> +DEF_CONST (int16_t, 15, 1024)
> +DEF_CONST (int16_t, 15, 2048)
> +
> +DEF_CONST (int32_t, 15, 2)
> +DEF_CONST (int32_t, 15, 4)
> +DEF_CONST (int32_t, 15, 8)
> +DEF_CONST (int32_t, 15, 16)
> +DEF_CONST (int32_t, 15, 32)
> +DEF_CONST (int32_t, 15, 64)
> +DEF_CONST (int32_t, 15, 128)
> +DEF_CONST (int32_t, 15, 256)
> +DEF_CONST (int32_t, 15, 512)
> +DEF_CONST (int32_t, 15, 1024)
> +
> +DEF_CONST (int64_t, 15, 2)
> +DEF_CONST (int64_t, 15, 4)
> +DEF_CONST (int64_t, 15, 8)
> +DEF_CONST (int64_t, 15, 16)
> +DEF_CONST (int64_t, 15, 32)
> +DEF_CONST (int64_t, 15, 64)
> +DEF_CONST (int64_t, 15, 128)
> +DEF_CONST (int64_t, 15, 256)
> +DEF_CONST (int64_t, 15, 512)
> +
> +/* { dg-final { scan-assembler-times {vmv\.v\.i\s+v[0-9]+,\s*15} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-3.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-3.c
> new file mode 100644
> index 00000000000..a9c8ae34ba7
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-3.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_CONST (_Float16, 0, 2)
> +DEF_CONST (_Float16, 0, 4)
> +DEF_CONST (_Float16, 0, 8)
> +DEF_CONST (_Float16, 0, 16)
> +DEF_CONST (_Float16, 0, 32)
> +DEF_CONST (_Float16, 0, 64)
> +DEF_CONST (_Float16, 0, 128)
> +DEF_CONST (_Float16, 0, 256)
> +DEF_CONST (_Float16, 0, 512)
> +DEF_CONST (_Float16, 0, 1024)
> +DEF_CONST (_Float16, 0, 2048)
> +
> +DEF_CONST (float, 0, 2)
> +DEF_CONST (float, 0, 4)
> +DEF_CONST (float, 0, 8)
> +DEF_CONST (float, 0, 16)
> +DEF_CONST (float, 0, 32)
> +DEF_CONST (float, 0, 64)
> +DEF_CONST (float, 0, 128)
> +DEF_CONST (float, 0, 256)
> +DEF_CONST (float, 0, 512)
> +DEF_CONST (float, 0, 1024)
> +
> +DEF_CONST (double, 0, 2)
> +DEF_CONST (double, 0, 4)
> +DEF_CONST (double, 0, 8)
> +DEF_CONST (double, 0, 16)
> +DEF_CONST (double, 0, 32)
> +DEF_CONST (double, 0, 64)
> +DEF_CONST (double, 0, 128)
> +DEF_CONST (double, 0, 256)
> +DEF_CONST (double, 0, 512)
> +
> +/* { dg-final { scan-assembler-times {vmv\.v\.i\s+v[0-9]+,\s*0} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-4.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-4.c
> new file mode 100644
> index 00000000000..50d1515aff6
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-4.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_CONST (_Float16, 8.88, 2)
> +DEF_CONST (_Float16, 8.88, 4)
> +DEF_CONST (_Float16, 8.88, 8)
> +DEF_CONST (_Float16, 8.88, 16)
> +DEF_CONST (_Float16, 8.88, 32)
> +DEF_CONST (_Float16, 8.88, 64)
> +DEF_CONST (_Float16, 8.88, 128)
> +DEF_CONST (_Float16, 8.88, 256)
> +DEF_CONST (_Float16, 8.88, 512)
> +DEF_CONST (_Float16, 8.88, 1024)
> +DEF_CONST (_Float16, 8.88, 2048)
> +
> +DEF_CONST (float, 8.88, 2)
> +DEF_CONST (float, 8.88, 4)
> +DEF_CONST (float, 8.88, 8)
> +DEF_CONST (float, 8.88, 16)
> +DEF_CONST (float, 8.88, 32)
> +DEF_CONST (float, 8.88, 64)
> +DEF_CONST (float, 8.88, 128)
> +DEF_CONST (float, 8.88, 256)
> +DEF_CONST (float, 8.88, 512)
> +DEF_CONST (float, 8.88, 1024)
> +
> +DEF_CONST (double, 8.88, 2)
> +DEF_CONST (double, 8.88, 4)
> +DEF_CONST (double, 8.88, 8)
> +DEF_CONST (double, 8.88, 16)
> +DEF_CONST (double, 8.88, 32)
> +DEF_CONST (double, 8.88, 64)
> +DEF_CONST (double, 8.88, 128)
> +DEF_CONST (double, 8.88, 256)
> +DEF_CONST (double, 8.88, 512)
> +
> +/* { dg-final { scan-assembler-times {vfmv\.v\.f\s+v[0-9]+,\s*[a-x0-9]+}
> 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-5.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-5.c
> new file mode 100644
> index 00000000000..afc2a877718
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/const-5.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_CONST (int16_t, 116, 2)
> +DEF_CONST (int16_t, 116, 4)
> +DEF_CONST (int16_t, 116, 8)
> +DEF_CONST (int16_t, 116, 16)
> +DEF_CONST (int16_t, 116, 32)
> +DEF_CONST (int16_t, 116, 64)
> +DEF_CONST (int16_t, 116, 128)
> +DEF_CONST (int16_t, 116, 256)
> +DEF_CONST (int16_t, 116, 512)
> +DEF_CONST (int16_t, 116, 1024)
> +DEF_CONST (int16_t, 116, 2048)
> +
> +DEF_CONST (int32_t, 116, 2)
> +DEF_CONST (int32_t, 116, 4)
> +DEF_CONST (int32_t, 116, 8)
> +DEF_CONST (int32_t, 116, 16)
> +DEF_CONST (int32_t, 116, 32)
> +DEF_CONST (int32_t, 116, 64)
> +DEF_CONST (int32_t, 116, 128)
> +DEF_CONST (int32_t, 116, 256)
> +DEF_CONST (int32_t, 116, 512)
> +DEF_CONST (int32_t, 116, 1024)
> +
> +DEF_CONST (int64_t, 116, 2)
> +DEF_CONST (int64_t, 116, 4)
> +DEF_CONST (int64_t, 116, 8)
> +DEF_CONST (int64_t, 116, 16)
> +DEF_CONST (int64_t, 116, 32)
> +DEF_CONST (int64_t, 116, 64)
> +DEF_CONST (int64_t, 116, 128)
> +DEF_CONST (int64_t, 116, 256)
> +DEF_CONST (int64_t, 116, 512)
> +
> +/* { dg-final { scan-assembler-times {vmv\.v\.x\s+v[0-9]+,\s*[a-x0-9]+}
> 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/def.h
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/def.h
> index 2a5baef747b..00a8a8d2849 100644
> --- a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/def.h
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/def.h
> @@ -150,3 +150,17 @@ typedef double v512df __attribute__ ((vector_size
> (4096)));
>      for (int i = 0; i < NUM; ++i)
>       \
>        a[i] = OP b[i];
>       \
>    }
> +
> +#define DEF_CONST(TYPE, VAL, NUM)
>       \
> +  void const_##TYPE##_##NUM (TYPE *restrict a)
>      \
> +  {
>       \
> +    for (int i = 0; i < NUM; ++i)
>       \
> +      a[i] = VAL;
>       \
> +  }
> +
> +#define DEF_SERIES(TYPE, BASE, STEP, NUM, SUFFIX)
>       \
> +  void series_##TYPE##_##SUFFIX (TYPE *restrict a)
>      \
> +  {
>       \
> +    for (TYPE i = 0; i < NUM; ++i)
>      \
> +      a[i] = (BASE) + i * (STEP);
>       \
> +  }
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-1.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-1.c
> new file mode 100644
> index 00000000000..b575bb9e60b
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-1.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_SERIES (int16_t, 0, 1, 2, b0s1n2)
> +DEF_SERIES (int16_t, 0, 1, 4, b0s1n4)
> +DEF_SERIES (int16_t, 0, 1, 8, b0s1n8)
> +DEF_SERIES (int16_t, 0, 1, 16, b0s1n16)
> +DEF_SERIES (int16_t, 0, 1, 32, b0s1n32)
> +DEF_SERIES (int16_t, 0, 1, 64, b0s1n64)
> +DEF_SERIES (int16_t, 0, 1, 128, b0s1n128)
> +DEF_SERIES (int16_t, 0, 1, 256, b0s1n256)
> +DEF_SERIES (int16_t, 0, 1, 512, b0s1n512)
> +DEF_SERIES (int16_t, 0, 1, 1024, b0s1n1024)
> +DEF_SERIES (int16_t, 0, 1, 2048, b0s1n2048)
> +
> +DEF_SERIES (int32_t, 0, 1, 2, b0s1n2)
> +DEF_SERIES (int32_t, 0, 1, 4, b0s1n4)
> +DEF_SERIES (int32_t, 0, 1, 8, b0s1n8)
> +DEF_SERIES (int32_t, 0, 1, 16, b0s1n16)
> +DEF_SERIES (int32_t, 0, 1, 32, b0s1n32)
> +DEF_SERIES (int32_t, 0, 1, 64, b0s1n64)
> +DEF_SERIES (int32_t, 0, 1, 128, b0s1n128)
> +DEF_SERIES (int32_t, 0, 1, 256, b0s1n256)
> +DEF_SERIES (int32_t, 0, 1, 512, b0s1n512)
> +DEF_SERIES (int32_t, 0, 1, 1024, b0s1n1024)
> +
> +DEF_SERIES (int64_t, 0, 1, 2, b0s1n2)
> +DEF_SERIES (int64_t, 0, 1, 4, b0s1n4)
> +DEF_SERIES (int64_t, 0, 1, 8, b0s1n8)
> +DEF_SERIES (int64_t, 0, 1, 16, b0s1n16)
> +DEF_SERIES (int64_t, 0, 1, 32, b0s1n32)
> +DEF_SERIES (int64_t, 0, 1, 64, b0s1n64)
> +DEF_SERIES (int64_t, 0, 1, 128, b0s1n128)
> +DEF_SERIES (int64_t, 0, 1, 256, b0s1n256)
> +DEF_SERIES (int64_t, 0, 1, 512, b0s1n512)
> +
> +/* { dg-final { scan-assembler-times {vid\.v\s+v[0-9]+} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-2.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-2.c
> new file mode 100644
> index 00000000000..c84eed158e5
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-2.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_SERIES (int16_t, 1, -1, 2, b1sm1n2)
> +DEF_SERIES (int16_t, 3, -1, 4, b3sm1n4)
> +DEF_SERIES (int16_t, 7, -1, 8, b7sm1n8)
> +DEF_SERIES (int16_t, 15, -1, 16, b15sm1n16)
> +DEF_SERIES (int16_t, 31, -1, 32, b31sm1n32)
> +DEF_SERIES (int16_t, 63, -1, 64, b63sm1n64)
> +DEF_SERIES (int16_t, 127, -1, 128, b127sm1n128)
> +DEF_SERIES (int16_t, 255, -1, 256, b255sm1n256)
> +DEF_SERIES (int16_t, 511, -1, 512, b511sm1n512)
> +DEF_SERIES (int16_t, 1023, -1, 1024, b1023sm1n1024)
> +DEF_SERIES (int16_t, 2047, -1, 2048, b2047sm1n2048)
> +
> +DEF_SERIES (int32_t, 1, -1, 2, b0sm1n2)
> +DEF_SERIES (int32_t, 3, -1, 4, b0sm1n4)
> +DEF_SERIES (int32_t, 7, -1, 8, b0sm1n8)
> +DEF_SERIES (int32_t, 15, -1, 16, b0sm1n16)
> +DEF_SERIES (int32_t, 31, -1, 32, b0sm1n32)
> +DEF_SERIES (int32_t, 63, -1, 64, b0sm1n64)
> +DEF_SERIES (int32_t, 127, -1, 128, b0sm1n128)
> +DEF_SERIES (int32_t, 255, -1, 256, b0sm1n256)
> +DEF_SERIES (int32_t, 511, -1, 512, b0sm1n512)
> +DEF_SERIES (int32_t, 1023, -1, 1024, b0sm1n1024)
> +
> +DEF_SERIES (int64_t, 1, -1, 2, b0sm1n2)
> +DEF_SERIES (int64_t, 3, -1, 4, b0sm1n4)
> +DEF_SERIES (int64_t, 7, -1, 8, b0sm1n8)
> +DEF_SERIES (int64_t, 15, -1, 16, b0sm1n16)
> +DEF_SERIES (int64_t, 31, -1, 32, b0sm1n32)
> +DEF_SERIES (int64_t, 63, -1, 64, b0sm1n64)
> +DEF_SERIES (int64_t, 127, -1, 128, b0sm1n128)
> +DEF_SERIES (int64_t, 255, -1, 256, b0sm1n256)
> +DEF_SERIES (int64_t, 511, -1, 512, b0sm1n512)
> +
> +/* { dg-final { scan-assembler-times {vid\.v\s+v[0-9]+} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-3.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-3.c
> new file mode 100644
> index 00000000000..16cce76dcf4
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-3.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_SERIES (int16_t, 0, 8, 2, b0s8n2)
> +DEF_SERIES (int16_t, 0, 8, 4, b0s8n4)
> +DEF_SERIES (int16_t, 0, 8, 8, b0s8n8)
> +DEF_SERIES (int16_t, 0, 8, 16, b0s8n16)
> +DEF_SERIES (int16_t, 0, 8, 32, b0s8n32)
> +DEF_SERIES (int16_t, 0, 8, 64, b0s8n64)
> +DEF_SERIES (int16_t, 0, 8, 128, b0s8n128)
> +DEF_SERIES (int16_t, 0, 8, 256, b0s8n256)
> +DEF_SERIES (int16_t, 0, 8, 512, b0s8n512)
> +DEF_SERIES (int16_t, 0, 8, 1024, b0s8n1024)
> +DEF_SERIES (int16_t, 0, 8, 2048, b0s8n2048)
> +
> +DEF_SERIES (int32_t, 0, 8, 2, b0s8n2)
> +DEF_SERIES (int32_t, 0, 8, 4, b0s8n4)
> +DEF_SERIES (int32_t, 0, 8, 8, b0s8n8)
> +DEF_SERIES (int32_t, 0, 8, 16, b0s8n16)
> +DEF_SERIES (int32_t, 0, 8, 32, b0s8n32)
> +DEF_SERIES (int32_t, 0, 8, 64, b0s8n64)
> +DEF_SERIES (int32_t, 0, 8, 128, b0s8n128)
> +DEF_SERIES (int32_t, 0, 8, 256, b0s8n256)
> +DEF_SERIES (int32_t, 0, 8, 512, b0s8n512)
> +DEF_SERIES (int32_t, 0, 8, 1024, b0s8n1024)
> +
> +DEF_SERIES (int64_t, 0, 8, 2, b0s8n2)
> +DEF_SERIES (int64_t, 0, 8, 4, b0s8n4)
> +DEF_SERIES (int64_t, 0, 8, 8, b0s8n8)
> +DEF_SERIES (int64_t, 0, 8, 16, b0s8n16)
> +DEF_SERIES (int64_t, 0, 8, 32, b0s8n32)
> +DEF_SERIES (int64_t, 0, 8, 64, b0s8n64)
> +DEF_SERIES (int64_t, 0, 8, 128, b0s8n128)
> +DEF_SERIES (int64_t, 0, 8, 256, b0s8n256)
> +DEF_SERIES (int64_t, 0, 8, 512, b0s8n512)
> +
> +/* { dg-final { scan-assembler-times {vid\.v\s+v[0-9]+} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> diff --git a/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-4.c
> b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-4.c
> new file mode 100644
> index 00000000000..966391e1f5c
> --- /dev/null
> +++ b/gcc/testsuite/gcc.target/riscv/rvv/autovec/vls/series-4.c
> @@ -0,0 +1,40 @@
> +/* { dg-do compile } */
> +/* { dg-options "-march=rv64gcv_zvfh_zvl4096b -mabi=lp64d -O3
> -fno-schedule-insns -fno-schedule-insns2 --param=riscv-autovec-lmul=m8
> -fno-builtin" } */
> +
> +#include "def.h"
> +
> +DEF_SERIES (int16_t, 67, 7, 2, b99s7n2)
> +DEF_SERIES (int16_t, 67, 7, 4, b99s7n4)
> +DEF_SERIES (int16_t, 67, 7, 8, b99s7n8)
> +DEF_SERIES (int16_t, 67, 7, 16, b99s7n16)
> +DEF_SERIES (int16_t, 67, 7, 32, b99s7n32)
> +DEF_SERIES (int16_t, 67, 7, 64, b99s7n64)
> +DEF_SERIES (int16_t, 67, 7, 128, b99s7n128)
> +DEF_SERIES (int16_t, 67, 7, 256, b99s7n256)
> +DEF_SERIES (int16_t, 67, 7, 512, b99s7n512)
> +DEF_SERIES (int16_t, 67, 7, 1024, b99s7n1024)
> +DEF_SERIES (int16_t, 67, 7, 2048, b99s7n2048)
> +
> +DEF_SERIES (int32_t, 76, 7, 2, b99s7n2)
> +DEF_SERIES (int32_t, 76, 7, 4, b99s7n4)
> +DEF_SERIES (int32_t, 76, 7, 8, b99s7n8)
> +DEF_SERIES (int32_t, 76, 7, 16, b99s7n16)
> +DEF_SERIES (int32_t, 76, 7, 32, b99s7n32)
> +DEF_SERIES (int32_t, 76, 7, 64, b99s7n64)
> +DEF_SERIES (int32_t, 76, 7, 128, b99s7n128)
> +DEF_SERIES (int32_t, 76, 7, 256, b99s7n256)
> +DEF_SERIES (int32_t, 76, 7, 512, b99s7n512)
> +DEF_SERIES (int32_t, 76, 7, 1024, b99s7n1024)
> +
> +DEF_SERIES (int64_t, 99, 7, 2, b99s7n2)
> +DEF_SERIES (int64_t, 99, 7, 4, b99s7n4)
> +DEF_SERIES (int64_t, 99, 7, 8, b99s7n8)
> +DEF_SERIES (int64_t, 99, 7, 16, b99s7n16)
> +DEF_SERIES (int64_t, 99, 7, 32, b99s7n32)
> +DEF_SERIES (int64_t, 99, 7, 64, b99s7n64)
> +DEF_SERIES (int64_t, 99, 7, 128, b99s7n128)
> +DEF_SERIES (int64_t, 99, 7, 256, b99s7n256)
> +DEF_SERIES (int64_t, 99, 7, 512, b99s7n512)
> +
> +/* { dg-final { scan-assembler-times {vid\.v\s+v[0-9]+} 30 } } */
> +/* { dg-final { scan-assembler-not {csrr} } } */
> --
> 2.36.1
>
>

Reply via email to