[testsuite] require sqrt_insn effective target where needed
[official-gcc.git] / gcc / testsuite / gcc.target / powerpc / vec-stril-10.c
blob10b5d610a9e14142708cfe71772f1aa58f27c465
1 /* { dg-do compile } */
2 /* { dg-options "-O1 -mdejagnu-cpu=power10" } */
3 /* See vec-stril-11.c for the same test with -O2 optimization. */
5 #include <altivec.h>
7 vector signed char
8 doString(vector signed char *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 char result = vec_stril (*vp);
13 if (vec_stril_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 {\mvstribl\.} 1 { target { be } } } } */
23 /* { dg-final { scan-assembler-times {\mvstribl\M[^.]} 0 { target { be } }} } */
24 /* { dg-final { scan-assembler-times {\mvstribr} 0 { target { be } } } } */
25 /* { dg-final { scan-assembler-times {\mvstribr\.} 1 { target { le } } } } */
26 /* { dg-final { scan-assembler-times {\mvstribr\M[^.]} 0 { target { le } }} } */
27 /* { dg-final { scan-assembler-times {\mvstribl} 0 { target { le } } } } */