diff gcc/testsuite/gcc.target/powerpc/vec-strir-18.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/gcc/testsuite/gcc.target/powerpc/vec-strir-18.c	Mon May 25 07:50:57 2020 +0900
@@ -0,0 +1,56 @@
+/* { dg-do run } */
+/* { dg-require-effective-target powerpc_future_hw } */
+/* { dg-options "-O1 -mdejagnu-cpu=future" } */
+/* See vec-strir-19.c for the same test with -O2 optimization.  */
+
+#include <altivec.h>
+
+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 ();
+}