summaryrefslogtreecommitdiff
path: root/src/intel/intel_driver.c
diff options
context:
space:
mode:
authorGuo Yejun <yejun.guo@intel.com>2014-05-27 07:10:04 +0800
committerZhigang Gong <zhigang.gong@intel.com>2014-05-28 09:08:38 +0800
commit3d8ea972a4a825b12c2b7deb41edf87b6e338f5d (patch)
tree5a8c2d6cc2ae3ebbd18799e333a5aa1c7fe683f1 /src/intel/intel_driver.c
parent604c0ee37c031a902f28a3a181e1314c8bab46f3 (diff)
separate runtime(libcl.so) and compiler(libgbe.so)
On embedded/handheld devices, storage and memory are scarce, it is necessary to provide only the OpenCL runtime library with small size, and only the executable binary kernel will be supported on such device. At the beginning of process (before function main), OpenCL runtime (libcl.so) will try to load the compiler (libgbe.so), the system's behavior is the same as before if successfully loaded, otherwise, the runtime assumes no OpenCL compiler in the system, and the device info will be changed as CL_DEVICE_COMPILER_AVAILABLE=false and CL_DEVICE_PROFILE="EMBEDDED_PROFILE", the clBuildProgram returns CL_COMPILER_NOT_AVAILABLE if the program is created with clCreateProgramWithSource, following the OpenCL spec. To simulate the case without OpenCL compiler, just delete the file libgbe.so, or export OCL_NON_COMPILER=1. Some explanation of the binary kernel interpreter (libinterp.a): libinterp.a is used to interpret the binary kernel inside runtime, and the runtime library libcl.so is built against libinterp.a. Since the code to interpret binary kernel is tightly integrated inside the compiler, to avoid code duplicate, a new file gbe_bin_interpreter.cpp is created to include some other .cpp files; to make libinterp.a small (the purpose to make libcl.so small), the macro GBE_COMPILER_AVAILABLE is used to make only the needed code active when build for libinterp.a. V2: code base is changed to call function gbe_set_image_base_index in gbe_bin_generater, while this function is modified in this patch as gbe_set_image_base_index_compiler, fix it accordingly. Signed-off-by: Guo Yejun <yejun.guo@intel.com> Reviewed-by: "Yang, Rong R" <rong.r.yang@intel.com> Tested-by: Zhigang Gong <zhigang.gong@linux.intel.com>
Diffstat (limited to 'src/intel/intel_driver.c')
-rw-r--r--src/intel/intel_driver.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/intel/intel_driver.c b/src/intel/intel_driver.c
index 08d6bc0c..aa313446 100644
--- a/src/intel/intel_driver.c
+++ b/src/intel/intel_driver.c
@@ -399,7 +399,8 @@ cl_intel_driver_delete(intel_driver_t *driver)
intel_driver_terminate(driver);
intel_driver_delete(driver);
}
-#include "program.h"
+
+#include "cl_gbe_loader.h"
static intel_driver_t*
cl_intel_driver_new(cl_context_prop props)
{
@@ -409,7 +410,9 @@ cl_intel_driver_new(cl_context_prop props)
/* We use the first 2 slots(0,1) for all the bufs.
* Notify the gbe this base index, thus gbe can avoid conflicts
* when it allocates slots for images*/
- gbe_set_image_base_index(3);
+ if (CompilerSupported())
+ gbe_set_image_base_index_compiler(3);
+ gbe_set_image_base_index_interp(3);
exit:
return driver;
error: