Test for __builtin_prefetch.
authorJanis Johnson <janis@gcc.gnu.org>
Tue, 4 Dec 2001 00:54:21 +0000 (00:54 +0000)
committerJanis Johnson <janis@gcc.gnu.org>
Tue, 4 Dec 2001 00:54:21 +0000 (00:54 +0000)
From-SVN: r47584

gcc/testsuite/gcc.c-torture/execute/builtin-prefetch-1.c [new file with mode: 0644]

diff --git a/gcc/testsuite/gcc.c-torture/execute/builtin-prefetch-1.c b/gcc/testsuite/gcc.c-torture/execute/builtin-prefetch-1.c
new file mode 100644 (file)
index 0000000..0d32f16
--- /dev/null
@@ -0,0 +1,59 @@
+/* Test that __builtin_prefetch does no harm.
+
+   Prefetch using all valid combinations of rw and locality values.
+   These must be compile-time constants.  */
+
+#define NO_TEMPORAL_LOCALITY 0
+#define LOW_TEMPORAL_LOCALITY 1
+#define MODERATE_TEMPORAL_LOCALITY 1
+#define HIGH_TEMPORAL_LOCALITY 3
+
+#define WRITE_ACCESS 1
+#define READ_ACCESS 0
+
+enum locality { none, low, moderate, high };
+enum rw { read, write };
+
+int arr[10];
+
+void
+good_const (int *p)
+{
+  __builtin_prefetch (p, 0, 0);
+  __builtin_prefetch (p, 0, 1);
+  __builtin_prefetch (p, 0, 2);
+  __builtin_prefetch (p, READ_ACCESS, 3);
+  __builtin_prefetch (p, 1, NO_TEMPORAL_LOCALITY);
+  __builtin_prefetch (p, 1, LOW_TEMPORAL_LOCALITY);
+  __builtin_prefetch (p, 1, MODERATE_TEMPORAL_LOCALITY);
+  __builtin_prefetch (p, WRITE_ACCESS, HIGH_TEMPORAL_LOCALITY);
+}
+
+void
+good_enum (int *p)
+{
+    __builtin_prefetch (p, read, none);
+    __builtin_prefetch (p, read, low);
+    __builtin_prefetch (p, read, moderate);
+    __builtin_prefetch (p, read, high);
+    __builtin_prefetch (p, write, none);
+    __builtin_prefetch (p, write, low);
+    __builtin_prefetch (p, write, moderate);
+    __builtin_prefetch (p, write, high);
+}
+
+void
+good_expr (int *p)
+{
+  __builtin_prefetch (p, 1 - 1, 6 - (2 * 3));
+  __builtin_prefetch (p, 1 + 0, 1 + 2);
+}
+
+int
+main ()
+{
+  good_const (arr);
+  good_enum (arr);
+  good_expr (arr);
+  exit (0);
+}