cl: Add atomic_max local tests

Submitted by Aaron Watry on Sept. 8, 2014, 2:30 p.m.

Details

Message ID 1410186656-14855-1-git-send-email-awatry@gmail.com
State New
Headers show

Not browsing as part of any series.

Commit Message

Aaron Watry Sept. 8, 2014, 2:30 p.m.
Passes on radeonsi (Pitcairn), fails on r600g (CEDAR).

Signed-off-by: Aaron Watry <awatry@gmail.com>
---
 .../execute/builtin/atomic/atomic_max-local.cl     | 69 ++++++++++++++++++++++
 1 file changed, 69 insertions(+)
 create mode 100644 tests/cl/program/execute/builtin/atomic/atomic_max-local.cl

Patch hide | download patch | download mbox

diff --git a/tests/cl/program/execute/builtin/atomic/atomic_max-local.cl b/tests/cl/program/execute/builtin/atomic/atomic_max-local.cl
new file mode 100644
index 0000000..353b90e
--- /dev/null
+++ b/tests/cl/program/execute/builtin/atomic/atomic_max-local.cl
@@ -0,0 +1,69 @@ 
+/*!
+[config]
+name: atomic_max local
+clc_version_min: 11
+
+[test]
+name: simple int
+kernel_name: simple_int
+dimensions: 1
+global_size: 1 0 0
+local_size: 1 0 0
+arg_out: 0 buffer int[2] -2 -1
+arg_in:  1 buffer int[1] NULL
+arg_in:  2 int           -2
+arg_in:  3 int           -1
+
+[test]
+name: simple uint
+kernel_name: simple_uint
+dimensions: 1
+global_size: 1 0 0
+local_size:  1 0 0
+arg_out: 0 buffer uint[2] 2 3
+arg_in:  1 buffer uint[1] NULL
+arg_in:  2 uint           2
+arg_in:  3 uint           3
+
+[test]
+name: threads
+kernel_name: threads_int
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer int[1] 7
+arg_in:  1 buffer int[1] NULL
+
+[test]
+name: threads
+kernel_name: threads_uint
+dimensions: 1
+global_size: 8 0 0
+local_size:  8 0 0
+arg_out: 0 buffer uint[1] 7
+arg_in:  1 buffer uint[1] NULL
+
+!*/
+
+#define SIMPLE_TEST(TYPE) \
+kernel void simple_##TYPE(global TYPE *out, local TYPE *mem, TYPE initial, TYPE other) { \
+	*mem = initial; \
+	TYPE a = atomic_max(mem, other); \
+	out[0] = a; \
+	out[1] = *mem; \
+}
+
+#define THREADS_TEST(TYPE) \
+kernel void threads_##TYPE(global TYPE *out, local TYPE *mem) { \
+	*mem = 0; \
+	barrier(CLK_LOCAL_MEM_FENCE); \
+	atomic_max(mem, get_global_id(0)); \
+	barrier(CLK_LOCAL_MEM_FENCE); \
+	*out = *mem; \
+}
+
+SIMPLE_TEST(int)
+SIMPLE_TEST(uint)
+
+THREADS_TEST(int)
+THREADS_TEST(uint)