From 7508f4be683726f499870f98ac5c94041e0b7a79 Mon Sep 17 00:00:00 2001 From: Junyan He Date: Fri, 13 Jun 2014 15:07:44 +0800 Subject: Add test cases for 1d image fill and copy Signed-off-by: Junyan He Reviewed-by: Zhigang Gong --- utests/compiler_fill_image_1d.cpp | 50 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 utests/compiler_fill_image_1d.cpp (limited to 'utests/compiler_fill_image_1d.cpp') diff --git a/utests/compiler_fill_image_1d.cpp b/utests/compiler_fill_image_1d.cpp new file mode 100644 index 00000000..e644c5f8 --- /dev/null +++ b/utests/compiler_fill_image_1d.cpp @@ -0,0 +1,50 @@ +#include +#include "utest_helper.hpp" + +static void compiler_fill_image_1d(void) +{ + const size_t w = 2048; + cl_image_format format; + cl_image_desc desc; + + memset(&desc, 0x0, sizeof(cl_image_desc)); + memset(&format, 0x0, sizeof(cl_image_format)); + + format.image_channel_order = CL_RGBA; + format.image_channel_data_type = CL_UNSIGNED_INT8; + desc.image_type = CL_MEM_OBJECT_IMAGE1D; + desc.image_width = w; + desc.image_row_pitch = 0; + + // Setup kernel and images + OCL_CREATE_KERNEL("test_fill_image_1d"); + + OCL_CREATE_IMAGE(buf[0], 0, &format, &desc, NULL); + + OCL_MAP_BUFFER_GTT(0); + for (uint32_t i = 0; i < w; i++) { + ((uint32_t*)buf_data[0])[i] = 0; + } + OCL_UNMAP_BUFFER_GTT(0); + + // Run the kernel + OCL_SET_ARG(0, sizeof(cl_mem), &buf[0]); + globals[0] = w/2; + locals[0] = 16; + OCL_NDRANGE(1); + + // Check result + OCL_MAP_BUFFER_GTT(0); + //printf("------ The image result is: -------\n"); + for (uint32_t i = 0; i < w/2; i++) { + //printf(" %2x", ((uint32_t *)buf_data[0])[i]); + OCL_ASSERT(((uint32_t*)buf_data[0])[i] == 0x03020100); + } + for (uint32_t i = w/2; i < w; i++) { + //printf(" %2x", ((uint32_t *)buf_data[0])[i]); + OCL_ASSERT(((uint32_t*)buf_data[0])[i] == 0); + } + OCL_UNMAP_BUFFER_GTT(0); +} + +MAKE_UTEST_FROM_FUNCTION(compiler_fill_image_1d); -- cgit v1.2.1