简介
clFinish 会进入阻塞状态,直到前面提交到命令队列的 OpenCL 命令发送到和命令队列关联的设备,并且执行完成。它作为一个同步点,会等待命令队列中所有的 OpenCL 命令执行完成,该操作对某些时候只需两个命令的同步或少数几个命令的同步来说开销较大。使用事件对象来同步就很好的解决了该问题,它用于某些指定事件的同步。
执行内核
在介绍具体示例之前,先通过 clEnqueueNDRangeKernel
函数来介绍事件对象。
cl_int clEnqueueNDRangeKernel(cl_command_queue command_queue,
cl_kernel kernel,
cl_uint work_dim,
const size_t *global_work_offset,
const size_t *global_work_size,
const size_t *local_work_size,
cl_uint num_events_in_wait_list,
const cl_event *event_wait_list,
cl_event *event)
相关参数描述如下:
- command_queue:命令队列。内核程序将被提交到这个命令队列,并且在和该命令队列关联的设备上执行;
- kernel:内核对象。
kernel
和command_queue
关联的 OpenCL 上下文必须相同; - work_dim:维度数,每个维度有单独全局