[Piglit] [PATCH 1/2] cl: Add global atomic_cmpxchg tests

Jan Vesely jan.vesely at rutgers.edu
Mon Jun 13 15:23:49 UTC 2016


Passes on CUDA, beignet, clover on kaveri, and intel CPU.

Signed-off-by: Jan Vesely <jan.vesely at rutgers.edu>
---
 .../builtin/atomic/atomic_cmpxchg-global-return.cl | 74 ++++++++++++++++++++++
 .../builtin/atomic/atomic_cmpxchg-global.cl        | 69 ++++++++++++++++++++
 2 files changed, 143 insertions(+)
 create mode 100644 tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global-return.cl
 create mode 100644 tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global.cl

diff --git a/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global-return.cl b/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global-return.cl
new file mode 100644
index 0000000..2cc1031
--- /dev/null
+++ b/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global-return.cl
@@ -0,0 +1,74 @@
+/*!
+[config]
+name: atomic_cmpxchg global return
+clc_version_min: 11
+
+[test]
+name: simple int
+kernel_name: simple_int
+dimensions: 1
+global_size: 1 0 0
+arg_out: 0 buffer int[2]  5 -4
+arg_in:  0 buffer int[2] -4 -4
+arg_in:  1 buffer int[2] -4  3
+arg_in:  2 buffer int[2]  5  5
+arg_out: 3 buffer int[2] -4 -4
+
+[test]
+name: simple uint
+kernel_name: simple_uint
+dimensions: 1
+global_size: 1 0 0
+arg_out: 0 buffer uint[2] 5 4
+arg_in:  0 buffer uint[2] 4 4
+arg_in:  1 buffer uint[2] 4 3
+arg_in:  2 buffer uint[2] 5 5
+arg_out: 3 buffer uint[2] 4 4
+
+[test]
+name: threads int
+kernel_name: threads_int
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer int[1] 8
+arg_in:  0 buffer int[1] 0
+arg_out: 1 buffer int[8] 0 1 2 3 4 5 6 7
+
+[test]
+name: threads uint
+kernel_name: threads_uint
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer uint[1] 8
+arg_in:  0 buffer uint[1] 0
+arg_out: 1 buffer uint[8] 0 1 2 3 4 5 6 7
+
+!*/
+
+#define SIMPLE_TEST(TYPE) \
+kernel void simple_##TYPE(global TYPE *initial, global TYPE *compare, global TYPE *value, global TYPE *old) { \
+	old[0] = atomic_cmpxchg(initial, compare[0], value[0]); \
+	old[1] = atomic_cmpxchg(initial+1, compare[1], value[1]); \
+}
+
+#define THREADS_TEST(TYPE) \
+kernel void threads_##TYPE(global TYPE *out, global TYPE *old) { \
+	int i; \
+	barrier(CLK_GLOBAL_MEM_FENCE); \
+	TYPE id = get_global_id(0); \
+	for(i = 0; i < get_global_size(0); i++){ \
+		TYPE old_val = atomic_cmpxchg(out, id, id+1); \
+		if (old_val == id) /* success */ \
+			old[id] = old_val; \
+		barrier(CLK_GLOBAL_MEM_FENCE); \
+	} \
+}
+
+SIMPLE_TEST(int)
+SIMPLE_TEST(uint)
+
+THREADS_TEST(int)
+THREADS_TEST(uint)
+
diff --git a/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global.cl b/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global.cl
new file mode 100644
index 0000000..05cf401
--- /dev/null
+++ b/tests/cl/program/execute/builtin/atomic/atomic_cmpxchg-global.cl
@@ -0,0 +1,69 @@
+/*!
+[config]
+name: atomic_cmpxchg global
+clc_version_min: 11
+
+[test]
+name: simple int
+kernel_name: simple_int
+dimensions: 1
+global_size: 1 0 0
+arg_out: 0 buffer int[2]  5 -4
+arg_in:  0 buffer int[2] -4 -4
+arg_in:  1 buffer int[2] -4  3
+arg_in:  2 buffer int[2]  5  5
+
+[test]
+name: simple uint
+kernel_name: simple_uint
+dimensions: 1
+global_size: 1 0 0
+arg_out: 0 buffer uint[2] 5 4
+arg_in:  0 buffer uint[2] 4 4
+arg_in:  1 buffer uint[2] 4 3
+arg_in:  2 buffer uint[2] 5 5
+
+[test]
+name: threads int
+kernel_name: threads_int
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer int[1] 8
+arg_in:  0 buffer int[1] 0
+
+[test]
+name: threads uint
+kernel_name: threads_uint
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer uint[1] 8
+arg_in:  0 buffer uint[1] 0
+
+!*/
+
+#define SIMPLE_TEST(TYPE) \
+kernel void simple_##TYPE(global TYPE *initial, global TYPE *compare, global TYPE *value) { \
+	atomic_cmpxchg(initial, compare[0], value[0]); \
+	atomic_cmpxchg(initial+1, compare[1], value[1]); \
+}
+
+#define THREADS_TEST(TYPE) \
+kernel void threads_##TYPE(global TYPE *out) { \
+	int i; \
+	barrier(CLK_GLOBAL_MEM_FENCE); \
+	TYPE id = get_global_id(0); \
+	for(i = 0; i < get_global_size(0); i++){ \
+		if (i == id){ \
+			atomic_cmpxchg(out, id, id+1); \
+		} \
+		barrier(CLK_GLOBAL_MEM_FENCE); \
+	} \
+}
+
+SIMPLE_TEST(int)
+SIMPLE_TEST(uint)
+
+THREADS_TEST(int)
+THREADS_TEST(uint)
-- 
2.7.4



More information about the Piglit mailing list