summaryrefslogtreecommitdiff
path: root/utests/compiler_local_memory_barrier_wg64.cpp
diff options
context:
space:
mode:
authorBenjamin Segovia <benjamin.segovia@intel.com>2012-11-13 20:55:06 -0800
committerBenjamin Segovia <benjamin.segovia@intel.com>2012-11-13 20:55:06 -0800
commitf784e97f55463126ea1b7d6587a2fe416d65764e (patch)
treed14dc9a524031fdf09d065058b3685e9f5d2de0a /utests/compiler_local_memory_barrier_wg64.cpp
parentf6372ac33cf964cdf2933e6ebc7fd9b5d931e7ff (diff)
downloadbeignet-f784e97f55463126ea1b7d6587a2fe416d65764e.tar.gz
Added complete support for barrier (and use of SLM)
Added some tests to assert this functionnality
Diffstat (limited to 'utests/compiler_local_memory_barrier_wg64.cpp')
-rw-r--r--utests/compiler_local_memory_barrier_wg64.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/utests/compiler_local_memory_barrier_wg64.cpp b/utests/compiler_local_memory_barrier_wg64.cpp
new file mode 100644
index 00000000..0cb69f55
--- /dev/null
+++ b/utests/compiler_local_memory_barrier_wg64.cpp
@@ -0,0 +1,46 @@
+/*
+ * Copyright © 2012 Intel Corporation
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * Author: Benjamin Segovia <benjamin.segovia@intel.com>
+ */
+
+#include "utest_helper.hpp"
+
+static void compiler_local_memory_barrier_wg64(void)
+{
+ const size_t n = 1024;
+
+ // Setup kernel and buffers
+ OCL_CREATE_KERNEL("compiler_local_memory_barrier_wg64");
+ OCL_CREATE_BUFFER(buf[0], 0, n * sizeof(uint32_t), NULL);
+ OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]);
+ OCL_SET_ARG(1, 256, NULL); // 64 x int
+
+ // Run the kernel
+ globals[0] = n;
+ locals[0] = 64;
+ OCL_NDRANGE(1);
+ OCL_MAP_BUFFER(0);
+
+ // Check results
+ uint32_t *dst = (uint32_t*)buf_data[0];
+ for (uint32_t i = 0; i < n; i+=64)
+ for (uint32_t j = 0; j < 64; ++j)
+ OCL_ASSERT(dst[i+j] == 63-j);
+}
+
+MAKE_UTEST_FROM_FUNCTION(compiler_local_memory_barrier_wg64);
+