1 /* { dg-do run } */
2 /* { dg-options "-O3 -mzarch -march=z13 --save-temps" } */
3 /* { dg-require-effective-target s390_vx } */
4
5 typedef unsigned char uv16qi __attribute__((vector_size(16)));
6 typedef unsigned short uv8hi __attribute__((vector_size(16)));
7 typedef unsigned int uv4si __attribute__((vector_size(16)));
8 typedef unsigned long long uv2di __attribute__((vector_size(16)));
9
10 uv2di __attribute__((noinline))
foo1()11 foo1 ()
12 {
13 return (uv2di){ 0x7f0f, 0x7f0f };
14 }
15 /* { dg-final { scan-assembler-times "vrepig\t%v24,32527" 1 } } */
16
17 uv4si __attribute__((noinline))
foo2()18 foo2 ()
19 {
20 return (uv4si){ 0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f };
21 }
22 /* { dg-final { scan-assembler-times "vrepif\t%v24,32527" 1 } } */
23
24 uv8hi __attribute__((noinline))
foo3()25 foo3 ()
26 {
27 return (uv8hi){ 0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f,
28 0x7f0f, 0x7f0f, 0x7f0f, 0x7f0f };
29 }
30 /* { dg-final { scan-assembler-times "vrepih\t%v24,32527" 1 } } */
31
32 uv16qi __attribute__((noinline))
foo4()33 foo4 ()
34 {
35 return (uv16qi){ 0x77, 0x77, 0x77, 0x77,
36 0x77, 0x77, 0x77, 0x77,
37 0x77, 0x77, 0x77, 0x77,
38 0x77, 0x77, 0x77, 0x77 };
39 }
40 /* { dg-final { scan-assembler-times "vrepib\t%v24,119" 1 } } */
41
42 int
main()43 main ()
44 {
45 if (foo1()[1] != 0x7f0f)
46 __builtin_abort ();
47
48 if (foo2()[1] != 0x7f0f)
49 __builtin_abort ();
50
51 if (foo3()[1] != 0x7f0f)
52 __builtin_abort ();
53
54 if (foo4()[1] != 0x77)
55 __builtin_abort ();
56
57 return 0;
58 }
59