diff options
author | Guo Yejun <yejun.guo@intel.com> | 2014-05-27 07:10:04 +0800 |
---|---|---|
committer | Zhigang Gong <zhigang.gong@intel.com> | 2014-05-28 09:08:38 +0800 |
commit | 3d8ea972a4a825b12c2b7deb41edf87b6e338f5d (patch) | |
tree | 5a8c2d6cc2ae3ebbd18799e333a5aa1c7fe683f1 /src/intel/intel_driver.c | |
parent | 604c0ee37c031a902f28a3a181e1314c8bab46f3 (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.c | 7 |
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: |