/* { dg-do run { target { power10_hw } } } */ /* { dg-do link { target { ! power10_hw } } } */ /* { dg-require-effective-target power10_ok } */ /* { dg-options "-O1 -mdejagnu-cpu=power10" } */ /* See vec-strir-19.c for the same test with -O2 optimization. */ #include extern void abort (void); vector signed char doString(vector signed char *vp) { /* Though two built-in functions are called, the implementation should use a single instruction to implement both with -O1. */ vector signed char result = vec_strir (*vp); if (vec_strir_p (*vp)) return result; else return doString (vp + 1); } int main (int argc, char *argv []) { vector signed char composed_string [4] = { { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0xf, 0x11 }, { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0x0, 0xf, 0x11 }, { 0x1, 0x2, 0xf3, 0x0, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0x0, 0x11 }, { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0x0, 0x11 } }; vector signed char expected0 = { 0x1, 0x2, 0xf3, 0x4, 0x5, 0x6, 0x7, 0x8, 0x9, 0xa, 0xb, 0xc, 0xd, 0xe2, 0xf, 0x11 }; vector signed char expected1 = { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0xf, 0x11 }; vector signed char expected2 = { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x11 }; vector signed char expected3 = { 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x11 }; if (!vec_all_eq (doString (&composed_string[0]), expected1)) abort (); if (!vec_all_eq (doString (&composed_string[1]), expected1)) abort (); if (!vec_all_eq (doString (&composed_string[2]), expected2)) abort (); if (!vec_all_eq (doString (&composed_string[3]), expected3)) abort (); }