summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/aarch64/sve_unpack_unsigned_1.c
blob: fa8de963264b3660f81751f13a64d5a8a82e957c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
/* { dg-do compile } */
/* { dg-options "-O2 -ftree-vectorize -fno-inline -march=armv8-a+sve" } */

#include <stdint.h>

#define UNPACK(TYPED, TYPES)				\
void __attribute__ ((noinline, noclone))		\
unpack_##TYPED##_##TYPES (TYPED *d, TYPES *s, int size)	\
{							\
  for (int i = 0; i < size; i++)			\
    d[i] = s[i] + 1;					\
}

#define TEST_ALL(T)			\
  T (int64_t, uint32_t)			\
  T (int32_t, uint16_t)			\
  T (int16_t, uint8_t)			\
  T (uint64_t, uint32_t)		\
  T (uint32_t, uint16_t)		\
  T (uint16_t, uint8_t)

TEST_ALL (UNPACK)

/* { dg-final { scan-assembler-times {\tuunpkhi\tz[0-9]+\.d, z[0-9]+\.s\n} 2 } } */
/* { dg-final { scan-assembler-times {\tuunpkhi\tz[0-9]+\.s, z[0-9]+\.h\n} 2 } } */
/* { dg-final { scan-assembler-times {\tuunpkhi\tz[0-9]+\.h, z[0-9]+\.b\n} 2 } } */

/* { dg-final { scan-assembler-times {\tuunpklo\tz[0-9]+\.d, z[0-9]+\.s\n} 2 } } */
/* { dg-final { scan-assembler-times {\tuunpklo\tz[0-9]+\.s, z[0-9]+\.h\n} 2 } } */
/* { dg-final { scan-assembler-times {\tuunpklo\tz[0-9]+\.h, z[0-9]+\.b\n} 2 } } */