annotate gcc/testsuite/gcc.target/powerpc/vec-strir-18.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 "-O1 -mdejagnu-cpu=future" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
4 /* See vec-strir-19.c for the same test with -O2 optimization. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
5
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
6 #include <altivec.h>
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
7
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 extern void abort (void);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 vector signed char
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 doString(vector signed char *vp)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 /* Though two built-in functions are called, the implementation
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 should use a single instruction to implement both with -O1. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 vector signed char result = vec_strir (*vp);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 if (vec_strir_p (*vp))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 return result;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18 else
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 return doString (vp + 1);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 int main (int argc, char *argv [])
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 vector signed char composed_string [4] = {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0xf, 0x11 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 { 0x1, 0x2, 0xf3, 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, 0xf3, 0x0, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0x0, 0x11 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0x0, 0x11 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 vector signed char expected0 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 vector signed char expected1 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xf, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41 vector signed char expected2 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44 vector signed char expected3 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x11 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 if (!vec_all_eq (doString (&composed_string[0]), 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[1]), expected1))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
51 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
52 if (!vec_all_eq (doString (&composed_string[2]), expected2))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
53 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
54 if (!vec_all_eq (doString (&composed_string[3]), expected3))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
55 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
56 }