/*
* cl_context.h - CL context
*
* Copyright (c) 2015 Intel Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* Author: Wind Yuan <feng.yuan@intel.com>
*/
#ifndef XCAM_CL_CONTEXT_H
#define XCAM_CL_CONTEXT_H
#include <xcam_std.h>
#include <map>
#include <list>
#include <CL/cl.h>
#include <ocl/cl_event.h>
namespace XCam {
class CLKernel;
class CLDevice;
class CLCommandQueue;
class CLVaBuffer;
class CLVaImage;
class CLIntelContext;
/* default context:
* SmartPtr<CLContext> context = CLDevice::instance()->get_context();
*/
class CLContext {
//typedef std::map<std::string, SmartPtr<CLKernel>> CLKernelMap;
typedef std::list<SmartPtr<CLCommandQueue>> CLCmdQueueList;
friend class CLDevice;
friend class CLKernel;
friend class CLMemory;
friend class CLBuffer;
friend class CLSubBuffer;
friend class CLImage;
friend class CLImage2D;
friend class CLImage2DArray;
friend class CLVaBuffer;
friend class CLVaImage;
friend class CLIntelContext;
public:
enum KernelBuildType {
KERNEL_BUILD_BINARY = 0,
KERNEL_BUILD_SOURCE,
};
virtual ~CLContext ();
cl_context get_context_id () {
return _context_id;
}
XCamReturn flush ();
XCamReturn finish ();
void terminate ();
private:
static void context_pfn_notify (
const char* erro_info, const void *private_info,
size_t cb, void *user_data);
static void program_pfn_notify (
cl_program program, void *user_data);
explicit CLContext (SmartPtr<CLDevice> &device);
SmartPtr<CLCommandQueue> create_cmd_queue (SmartPtr<CLContext> &self);
cl_kernel generate_kernel_id (
CLKernel *kernel,
const uint8_t *source,
size_t length,
KernelBuildType type,
uint8_t **gen_binary,
size_t *binary_size,
const char *build_option);
void destroy_kernel_id (cl_kernel &kernel_id);
XCamReturn execute_kernel (
const SmartPtr<CLKernel> kernel,
const SmartPtr<CLCommandQueue> queue,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
XCamReturn set_event_callback (
SmartPtr<CLEvent> &event, cl_int status,
void (*callback) (cl_event, cl_int, void*),
void *user_data);
//bool insert_kernel (SmartPtr<CLKernel> &kernel);
bool init_context ();
void destroy_context ();
bool is_valid () const {
return (_context_id != NULL);
}
bool init_cmd_queue (SmartPtr<CLContext> &self);
SmartPtr<CLCommandQueue> get_default_cmd_queue ();
//Memory, Image
cl_mem create_image (
cl_mem_flags flags, const cl_image_format& format,
const cl_image_desc &image_info, void *host_ptr = NULL);
void destroy_mem (cl_mem mem_id);
// Buffer
cl_mem create_buffer (uint32_t size, cl_mem_flags flags, void *host_ptr);
cl_mem create_sub_buffer (
cl_mem main_mem,
cl_buffer_region region,
cl_mem_flags flags = CL_MEM_READ_WRITE);
XCamReturn enqueue_read_buffer (
cl_mem buf_id, void *ptr,
uint32_t offset, uint32_t size,
bool block = true,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
XCamReturn enqueue_write_buffer (
cl_mem buf_id, void *ptr,
uint32_t offset, uint32_t size,
bool block = true,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
XCamReturn enqueue_map_buffer (
cl_mem buf_id, void *&ptr,
uint32_t offset, uint32_t size,
bool block = true,
cl_map_flags map_flags = CL_MAP_READ | CL_MAP_WRITE,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
XCamReturn enqueue_map_image (
cl_mem buf_id, void *&ptr,
const size_t *origin,
const size_t *region,
size_t *image_row_pitch,
size_t *image_slice_pitch,
bool block = true,
cl_map_flags map_flags = CL_MAP_READ | CL_MAP_WRITE,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
XCamReturn enqueue_unmap (
cl_mem mem_id,
void *ptr,
CLEventList &events_wait = CLEvent::EmptyList,
SmartPtr<CLEvent> &event_out = CLEvent::NullEvent);
// return valid event count
static uint32_t event_list_2_id_array (
CLEventList &events_wait,
cl_event *cl_events, uint32_t max_count);
XCAM_DEAD_COPY (CLContext);
private:
cl_context _context_id;
SmartPtr<CLDevice> _device;
//CLKernelMap _kernel_map;
CLCmdQueueList _cmd_queue_list;
};
class CLCommandQueue {
friend class CLContext;
public:
virtual ~CLCommandQueue ();
cl_command_queue get_cmd_queue_id () {
return _cmd_queue_id;
}
private:
explicit CLCommandQueue (SmartPtr<CLContext> &context, cl_command_queue id);
void destroy ();
XCAM_DEAD_COPY (CLCommandQueue);
private:
SmartPtr<CLContext> _context;
cl_command_queue _cmd_queue_id;
};
};
#endif //XCAM_CL_CONTEXT_H