opencl 内核执行命令入队]工作组工作项

Posted pengtangtang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了opencl 内核执行命令入队]工作组工作项相关的知识,希望对你有一定的参考价值。

1:将内核执行命令入队(该命令可被多个工作项执行)

cl_int clEnqueueNDRangeKernel(

cl_command_queue command_queue,

cl_kernel kernel,

cl_uint work_dim,          //数据的维度

const size_t * global_work_offset,   //各维度上的全局ID偏移量

const size_t* globak_work_size,    //各维度上工作项数目

const size_t* local_work_size,     //各 维度上一个工作组中的工作项数目

cl_uint num_events_wait_in_list,

const cl_event* event_wait_list,

cl_event* event

)

2:将内核执行命令入队(该命令只在一个工作项中执行)

cl_int clEnqueueTask(

cl_command_queue command_queue,

cl_kernel kernel,

cl_uint num_events_waite_in_list,

const cl_event* event_in_list,

cl_event* event

)

clEnqueueTask 和 clEnqueueNDRangeKernel的功能都是将核执行命令加入命令队列。而clEnqueueNDRangeKernel可以更好的划分数据,充分利用设备的资源

工作组和工作项的特点:

1、工作组中的工作项可以访问局部内存的同一块地址

2、工作组中的工作项可以进行同步

 

3:工作项相关函数

技术图片

 

 4:工作组相关函数

技术图片

 

 

以上是关于opencl 内核执行命令入队]工作组工作项的主要内容,如果未能解决你的问题,请参考以下文章

OpenCL 全局屏障工作项同步

OpenCL – 执行动态 for 循环

结合 OpenMP 和 OpenCL

OpenCL AMD S10000 双 GPU 执行

让 printf 语句在 openCL 内核代码中工作

一个简单的时间片轮转多道程序内核操作系统工作流程