annotate gcc/testsuite/gcc.target/powerpc/vec-strir-17.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
152
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
1 /* { dg-do run } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
2 /* { dg-require-effective-target powerpc_future_hw } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
3 /* { dg-options "-O2 -mdejagnu-cpu=future" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5 #include <altivec.h>
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7 extern void abort (void);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9 vector unsigned char
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 doString(vector unsigned char *vp)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 /* Tail recursion replaced with iteration with -O2. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 vector unsigned char result = vec_strir (*vp);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 if (vec_strir_p (*vp))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 return result;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 else
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 return doString (vp + 1);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 int main (int argc, char *argv [])
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 vector unsigned char composed_string [4] = {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 { 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x11 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 { 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 0x0, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x11 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 { 0x1, 0x2, 0x0, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 0x9, 0xa, 0xb, 0xc, 0xd, 0x0, 0xf, 0x11 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 { 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 0x9, 0xa, 0xb, 0xc, 0xd, 0x0, 0xf, 0x11 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33 vector unsigned char expected0 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34 { 0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 vector unsigned char expected1 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 0x0, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39 vector unsigned char expected2 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 vector unsigned char expected3 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 if (!vec_all_eq (doString (&composed_string[0]), expected1))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 if (!vec_all_eq (doString (&composed_string[1]), expected1))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
49 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
50 if (!vec_all_eq (doString (&composed_string[2]), expected2))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
51 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
52 if (!vec_all_eq (doString (&composed_string[3]), expected3))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
53 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
54 }