c++: normalizing ttp constraints [PR115656]
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / vec-strir_p-5.c
blobad02c97881a70e75752e960d4447aac29d782eb1
1 /* { dg-do run { target { power10_hw } } } */
2 /* { dg-do link { target { ! power10_hw } } } */
3 /* { dg-require-effective-target power10_ok } */
4 /* { dg-options "-mdejagnu-cpu=power10" } */
6 #include <altivec.h>
8 extern void abort (void);
10 /* Vector string isolate right-justified on array of unsigned short. */
11 int
12 sirj_p (vector unsigned short arg)
14 return vec_strir_p (arg);
17 int main (int argc, short *argv [])
19 vector unsigned short input1 =
20 { 0x1, 0x3, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
21 vector unsigned short expected1 =
22 { 0x1, 0x3, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
23 vector unsigned short input2 =
24 { 0x1, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
25 vector unsigned short expected2 =
26 { 0x0, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
27 vector unsigned short input3 =
28 { 0x1, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0x0 };
29 vector unsigned short expected3 =
30 { 0x0, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0x0 };
31 vector unsigned short input4 =
32 { 0x1, 0x3, 0x5, 0x7, 0x9, 0xb, 0xd, 0x0 };
33 vector unsigned short expected4 =
34 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0 };
36 if (sirj_p (input1))
37 abort ();
38 if (!sirj_p (input2))
39 abort ();
40 if (!sirj_p (input3))
41 abort ();
42 if (!sirj_p (input4))
43 abort ();