c++: normalizing ttp constraints [PR115656]
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / vec-strir-14.c
blobb5b360ab282a653fac10e63cfb6449bf637ecaf3
1 /* { dg-do compile } */
2 /* { dg-options "-O1 -mdejagnu-cpu=power10" } */
3 /* See vec-strir-15.c for the same test with -O2 optimization. */
5 #include <altivec.h>
7 vector signed short
8 doString(vector signed short *vp)
10 /* Though two built-in functions are called, the implementation
11 should use a single instruction to implement both with -O1. */
12 vector signed short result = vec_strir (*vp);
13 if (vec_strir_p (*vp))
14 return result;
15 else
16 return doString (vp + 1);
19 /* Enforce that a single dot-form instruction which is properly biased
20 for the target's endianness implements this built-in. */
22 /* { dg-final { scan-assembler-times {\mvstrihr\.} 1 { target { be } } } } */
23 /* { dg-final { scan-assembler-times {\mvstrihr\M[^.]} 0 { target { be } } } } */
24 /* { dg-final { scan-assembler-times {\mvstrihl} 0 { target { be } } } } */
25 /* { dg-final { scan-assembler-times {\mvstrihl\.} 1 { target { le } } } } */
26 /* { dg-final { scan-assembler-times {\mvstrihl\M[^.]} 0 { target { le } } } } */
27 /* { dg-final { scan-assembler-times {\mvstrihr} 0 { target { le } } } } */