123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 |
- #ifndef BOOST_COMPUTE_INTEROP_OPENGL_CONTEXT_HPP
- #define BOOST_COMPUTE_INTEROP_OPENGL_CONTEXT_HPP
- #include <boost/throw_exception.hpp>
- #include <boost/compute/device.hpp>
- #include <boost/compute/system.hpp>
- #include <boost/compute/context.hpp>
- #include <boost/compute/exception/unsupported_extension_error.hpp>
- #include <boost/compute/interop/opengl/cl_gl.hpp>
- #ifdef __APPLE__
- #include <OpenCL/cl_gl_ext.h>
- #include <OpenGL/OpenGL.h>
- #endif
- #ifdef __linux__
- #include <GL/glx.h>
- #endif
- namespace boost {
- namespace compute {
- inline context opengl_create_shared_context()
- {
-
- #if defined(__APPLE__)
- const char *cl_gl_sharing_extension = "cl_APPLE_gl_sharing";
- #else
- const char *cl_gl_sharing_extension = "cl_khr_gl_sharing";
- #endif
- #if defined(__APPLE__)
-
- CGLContextObj cgl_current_context = CGLGetCurrentContext();
- CGLShareGroupObj cgl_share_group = CGLGetShareGroup(cgl_current_context);
- cl_context_properties properties[] = {
- CL_CONTEXT_PROPERTY_USE_CGL_SHAREGROUP_APPLE,
- (cl_context_properties) cgl_share_group,
- 0
- };
- cl_int error = 0;
- cl_context cl_gl_context = clCreateContext(properties, 0, 0, 0, 0, &error);
- if(!cl_gl_context){
- BOOST_THROW_EXCEPTION(opencl_error(error));
- }
- return context(cl_gl_context, false);
- #else
- typedef cl_int(*GetGLContextInfoKHRFunction)(
- const cl_context_properties*, cl_gl_context_info, size_t, void *, size_t *
- );
- std::vector<platform> platforms = system::platforms();
- for(size_t i = 0; i < platforms.size(); i++){
- const platform &platform = platforms[i];
-
- if (!platform.supports_extension(cl_gl_sharing_extension))
- continue;
-
- GetGLContextInfoKHRFunction GetGLContextInfoKHR =
- reinterpret_cast<GetGLContextInfoKHRFunction>(
- reinterpret_cast<size_t>(
- platform.get_extension_function_address("clGetGLContextInfoKHR")
- )
- );
- if(!GetGLContextInfoKHR){
- continue;
- }
-
- cl_context_properties properties[] = {
- CL_CONTEXT_PLATFORM, (cl_context_properties) platform.id(),
- #if defined(__linux__)
- CL_GL_CONTEXT_KHR, (cl_context_properties) glXGetCurrentContext(),
- CL_GLX_DISPLAY_KHR, (cl_context_properties) glXGetCurrentDisplay(),
- #elif defined(_WIN32)
- CL_GL_CONTEXT_KHR, (cl_context_properties) wglGetCurrentContext(),
- CL_WGL_HDC_KHR, (cl_context_properties) wglGetCurrentDC(),
- #endif
- 0
- };
-
- cl_device_id gpu_id;
- cl_int ret = GetGLContextInfoKHR(
- properties,
- CL_CURRENT_DEVICE_FOR_GL_CONTEXT_KHR,
- sizeof(cl_device_id),
- &gpu_id,
- 0
- );
- if(ret != CL_SUCCESS){
- continue;
- }
-
- device gpu(gpu_id, false);
- if(!gpu.supports_extension(cl_gl_sharing_extension)){
- continue;
- }
-
- return context(gpu, properties);
- }
- #endif
-
- BOOST_THROW_EXCEPTION(
- unsupported_extension_error(cl_gl_sharing_extension)
- );
- }
- }
- }
- #endif
|