(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.target/
aarch64/
sve/
extend_4.c
       1  /* { dg-options "-O2 -ftree-vectorize -msve-vector-bits=512" } */
       2  
       3  #include <stdint.h>
       4  
       5  void
       6  f (int64_t *dst, int32_t *restrict src1, int16_t *restrict src2,
       7     int8_t *restrict src3)
       8  {
       9    for (int i = 0; i < 7; ++i)
      10      dst[i] += (int32_t) (src1[i] + (int16_t) (src2[i]
      11  					      + (int8_t) (src3[i] + 1)));
      12  }
      13  
      14  /* { dg-final { scan-assembler-times {\tld1b\tz[0-9]+\.d,} 1 } } */
      15  /* { dg-final { scan-assembler-times {\tld1h\tz[0-9]+\.d,} 1 } } */
      16  /* { dg-final { scan-assembler-times {\tld1w\tz[0-9]+\.d,} 1 } } */
      17  
      18  /* { dg-final { scan-assembler-times {\tadd\tz[0-9]+\.b, z[0-9]+\.b, #1\n} 1 } } */
      19  /* { dg-final { scan-assembler-times {\tadd\tz[0-9]+\.h, z[0-9]+\.h, z[0-9]+\.h\n} 1 } } */
      20  /* { dg-final { scan-assembler-times {\tadd\tz[0-9]+\.s, z[0-9]+\.s, z[0-9]+\.s\n} 1 } } */
      21  /* { dg-final { scan-assembler-times {\tadd\tz[0-9]+\.d, z[0-9]+\.d, z[0-9]+\.d\n} 1 } } */
      22  
      23  /* { dg-final { scan-assembler-times {\tsxtb\tz[0-9]+\.h,} 1 } } */
      24  /* { dg-final { scan-assembler-times {\tsxth\tz[0-9]+\.s,} 1 } } */
      25  /* { dg-final { scan-assembler-times {\tsxtw\tz[0-9]+\.d,} 1 } } */