annotate gcc/testsuite/gcc.target/powerpc/vec-strir-12.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 compile } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
2 /* { dg-options "-O1 -mdejagnu-cpu=future" } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
3 /* See vec-strir-13.c for the same test with -O2 optimization. */
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 vector unsigned short
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
8 doString(vector unsigned short *vp)
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
9 {
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
10 /* Though two built-in functions are called, the implementation
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
11 should use a single instruction to implement both with -O1. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
12 vector unsigned short result = vec_strir (*vp);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
13 if (vec_strir_p (*vp))
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
14 return result;
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
15 else
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
16 return doString (vp + 1);
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
17 }
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
18
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
19 /* Enforce that a single dot-form instruction which is properly biased
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
20 for the target's endianness implements this built-in. */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
21
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
22 /* { dg-final { scan-assembler-times {\mvstrihr\.} 1 { target { be } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
23 /* { dg-final { scan-assembler-times {\mvstrihr\M[^.]} 0 { target { be } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
24 /* { dg-final { scan-assembler-times {\mvstrihl} 0 { target { be } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
25 /* { dg-final { scan-assembler-times {\mvstrihl\.} 1 { target { le } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
26 /* { dg-final { scan-assembler-times {\mvstrihl\M[^.]} 0 { target { le } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
27 /* { dg-final { scan-assembler-times {\mvstrihr} 0 { target { le } } } } */
2b5abeee2509 update gcc11
anatofuz
parents:
diff changeset
28