annotate gcc/testsuite/gcc.target/powerpc/vec-strir-22.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-23.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 short
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 doString(vector signed short *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 short 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, short *argv [])
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 vector signed short composed_string [4] = {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 { 0x1, 0x3, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 { 0x1, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 { 0x1, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0x0 },
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28 { 0x1, 0x3, 0x5, 0x7, 0x9, 0x0, 0xd, 0xe }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
29 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
30
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
31 vector signed short expected0 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
32 { 0x1, 0x3, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
33 vector signed short expected1 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
34 { 0x0, 0x0, 0x5, 0x7, 0x9, 0xb, 0xd, 0xf };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
35 vector signed short expected2 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
36 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0 };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
37 vector signed short expected3 =
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
38 { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xd, 0xe };
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
39
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
40 if (!vec_all_eq (doString (&composed_string[0]), expected1))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
41 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
42 if (!vec_all_eq (doString (&composed_string[1]), expected1))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
43 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
44 if (!vec_all_eq (doString (&composed_string[2]), expected2))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
45 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
46 if (!vec_all_eq (doString (&composed_string[3]), expected3))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
47 abort ();
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
48 }