aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/s390/vector/vec-vrepi-1.c
blob: 27bf39e09638221904ecdc8fc5f17e4bd7f3dd5d (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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
/* { dg-do run } */
/* { dg-options "-O3 -mzarch -march=z13 --save-temps" } */
/* { dg-require-effective-target vector } */

typedef unsigned char     uv16qi __attribute__((vector_size(16)));
typedef unsigned short     uv8hi __attribute__((vector_size(16)));
typedef unsigned int       uv4si __attribute__((vector_size(16)));
typedef unsigned long long uv2di __attribute__((vector_size(16)));

uv2di __attribute__((noinline))
foo1 ()
{
  return (uv2di){ 0x7f0f, 0x7f0f };
}
/* { dg-final { scan-assembler-times "vrepig\t%v24,32527" 1 } } */

uv4si __attribute__((noinline))
foo2 ()
{
  return (uv4si){ 0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f };
}
/* { dg-final { scan-assembler-times "vrepif\t%v24,32527" 1 } } */

uv8hi __attribute__((noinline))
foo3 ()
{
  return (uv8hi){ 0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f,
      0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f };
}
/* { dg-final { scan-assembler-times "vrepih\t%v24,32527" 1 } } */

uv16qi __attribute__((noinline))
foo4 ()
{
  return (uv16qi){ 0x77, 0x77, 0x77, 0x77,
      0x77, 0x77, 0x77, 0x77,
      0x77, 0x77, 0x77, 0x77,
      0x77, 0x77, 0x77, 0x77 };
}
/* { dg-final { scan-assembler-times "vrepib\t%v24,119" 1 } } */

int
main ()
{
  if (foo1()[1] != 0x7f0f)
    __builtin_abort ();

  if (foo2()[1] != 0x7f0f)
    __builtin_abort ();

  if (foo3()[1] != 0x7f0f)
    __builtin_abort ();

  if (foo4()[1] != 0x77)
    __builtin_abort ();

  return 0;
}