summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/s390/vector/vec-genbytemask-1.c
blob: dfe19f1913b9f3e0d0f0d88f5f750084795ad426 (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
59
60
61
62
63
64
65
66
67
68
69
70
/* { 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){ 0xff00ff00ff00ff00, 0x00ff00ff00ff00ff };
}
/* { dg-final { scan-assembler-times "vgbm\t%v24,43605" 1 } } */

uv4si __attribute__((noinline))
foo2 ()
{
  return (uv4si){ 0xff0000ff, 0x0000ffff, 0xffff0000, 0x00ffff00 };
}
/* { dg-final { scan-assembler-times "vgbm\t%v24,37830" 1 } } */

uv8hi __attribute__((noinline))
foo3a ()
{
  return (uv8hi){ 0xff00, 0xff00, 0xff00, 0xff00,
      0xff00, 0xff00, 0xff00, 0xff00 };
}
/* { dg-final { scan-assembler-times "vgbm\t%v24,43690" 1 } } */

uv8hi __attribute__((noinline))
foo3b ()
{
  return (uv8hi){ 0x00ff, 0x00ff, 0x00ff, 0x00ff,
      0x00ff, 0x00ff, 0x00ff, 0x00ff };
}
/* { dg-final { scan-assembler-times "vgbm\t%v24,21845" 1 } } */

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

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

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

  if (foo3a()[1] != 0xff00)
    __builtin_abort ();

  if (foo3b()[1] != 0x00ff)
    __builtin_abort ();

  if (foo4()[1] != 0xff)
    __builtin_abort ();
  return 0;
}

/* { dg-final { cleanup-saved-temps } } */