From baf174e85ddb5399355281cd34d0f459d92124a7 Mon Sep 17 00:00:00 2001 From: Georgios Pinitas Date: Fri, 8 Sep 2017 19:47:30 +0100 Subject: COMPMID-485: Memory Manager Change-Id: Ib421b7622838f050038cd81e7426bb1413a7d6e6 Reviewed-on: http://mpd-gerrit.cambridge.arm.com/87376 Tested-by: Kaizen Reviewed-by: Anthony Barbier --- src/core/CL/OpenCL.cpp | 15 +++++++++++++++ 1 file changed, 15 insertions(+) (limited to 'src/core/CL/OpenCL.cpp') diff --git a/src/core/CL/OpenCL.cpp b/src/core/CL/OpenCL.cpp index 085e186543..0f44ad999f 100644 --- a/src/core/CL/OpenCL.cpp +++ b/src/core/CL/OpenCL.cpp @@ -95,6 +95,7 @@ bool CLSymbols::load(const std::string &library) clReleaseContext = reinterpret_cast(dlsym(handle, "clReleaseContext")); clRetainCommandQueue = reinterpret_cast(dlsym(handle, "clRetainCommandQueue")); clEnqueueUnmapMemObject = reinterpret_cast(dlsym(handle, "clEnqueueUnmapMemObject")); + clRetainMemObject = reinterpret_cast(dlsym(handle, "clRetainMemObject")); clReleaseMemObject = reinterpret_cast(dlsym(handle, "clReleaseMemObject")); clGetDeviceInfo = reinterpret_cast(dlsym(handle, "clGetDeviceInfo")); clGetDeviceIDs = reinterpret_cast(dlsym(handle, "clGetDeviceIDs")); @@ -175,6 +176,20 @@ cl_int clSetKernelArg( } } +cl_int clRetainMemObject(cl_mem memobj) +{ + arm_compute::CLSymbols::get().load_default(); + auto func = arm_compute::CLSymbols::get().clRetainMemObject; + if(func != nullptr) + { + return func(memobj); + } + else + { + return CL_OUT_OF_RESOURCES; + } +} + cl_int clReleaseMemObject(cl_mem memobj) { arm_compute::CLSymbols::get().load_default(); -- cgit v1.2.1