OpenCL教程 第二章 平台模型

#第二章 平台模型
上下文创建完成后就可以通过上下文来管理多个设备,但是主机端想要控制设备的话,需要将控制命令通过一个称为命令队列的结构传递个具体设备,每个设备最少需要一个命令队列控制,
命令队列是一种队列,服从先进先出的原则,主机将命令通过队列发送到设备端。
#####以下几个接口是关于命令队列的:

cl_command_queue clCreateCommandQueue (cl_context context,                    //队列所在上下文
                                       cl_device_id device,                   //队列所指向的设备
                                       const cl_queue_properties *properties, //队列的属性
                                       cl_int *errcode_ret)                   //错误指示信息

其中第三个参数有两个枚举型的选择:
这里写图片描述
在头文件中这两个枚举类型定义如下:

#define CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE      (1 << 0)    //1
#define CL_QUEUE_PROFILING_ENABLE                   (1 << 1)    //2
cl_int clGetCommandQueueInfo (cl_command_queue command_queue,
                              cl_command_queue_info param_name,
                              size_t param_value_size,
                              void *param_value,
                              size_t *param_value_size_ret)

同样,命令队列也可以查询信息,可查的信息内容如下:
这里写图片描述
队列和上下文一样都有引用计数这样一个参数,并且作用是一样的,具体参考上下文,计数接口为:

cl_int clRetainCommandQueue (cl_command_queue command_queue)
cl_int clReleaseCommandQueue (cl_command_queue command_queue)

#####一般创建命令队列的方法:

cl_command_queue *queues = new cl_command_queue[device_num];
for (cl_uint i = 0; i < device_num; i++){
    queues[i] = clCreateCommandQueue(context, devices[i], CL_QUEUE_PROFILING_ENABLE, &err);
    checkError(err, "Can't create queue");
}

#####查询队列属性的方法:

cl_command_queue_properties queue_pro;
clGetCommandQueueInfo(queues[0], CL_QUEUE_PROPERTIES, sizeof(cl_command_queue_properties), &queue_pro, NULL);
if (queue_pro == (1 << 0))cout << "CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE" << endl;
else if (queue_pro == (1 << 1))cout << "CL_QUEUE_PROFILING_ENABLE" << endl;
else if (queue_pro == ((1 << 0) | (1 << 1)))cout << "CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE|CL_QUEUE_PROFILING_ENABLE" << endl;

#####实验代码:

#include"opencl.h"
int main(){
    cl_uint platform_num;
    clGetPlatformIDs(0, NULL, &platform_num);
    cl_platform_id *platforms = new cl_platform_id[platform_num];
    clGetPlatformIDs(platform_num, platforms, NULL);
    cl_uint device_num;
    clGetDeviceIDs(platforms[0], CL_DEVICE_TYPE_ALL, 0, NULL, &device_num);
    cl_device_id *devices = new cl_device_id[device_num];
    clGetDeviceIDs(platforms[0], CL_DEVICE_TYPE_ALL, device_num, devices, NULL);
    cl_int err;
    cl_context context = clCreateContext(NULL, device_num, devices, NULL, NULL, &err);
    checkError(err, "Can't create context");
    cl_command_queue *queues = new cl_command_queue[device_num];
    for (cl_uint i = 0; i < device_num; i++){
        queues[i] = clCreateCommandQueue(context, devices[i], CL_QUEUE_PROFILING_ENABLE, &err);
        checkError(err, "Can't create queue");
    }
    cl_command_queue_properties queue_pro;
    clGetCommandQueueInfo(queues[0], CL_QUEUE_PROPERTIES, sizeof(cl_command_queue_properties), &queue_pro, NULL);
    if (queue_pro == (1 << 0))cout << "CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE" << endl;
    else if (queue_pro == (1 << 1))cout << "CL_QUEUE_PROFILING_ENABLE" << endl;
    else if (queue_pro == ((1 << 0) | (1 << 1)))cout << "CL_QUEUE_OUT_OF_ORDER_EXEC_MODE_ENABLE|CL_QUEUE_PROFILING_ENABLE" << endl;
    return 0;
}

#####实验结果:
这里写图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OpenCL是一种跨平台并行计算框架,可以用于利用不同设备的计算能力,如CPU和GPU。对于想要学习OpenCL的初学者来说,以下是一个完整的OpenCL中文入门教程。 首先,了解OpenCL的基本概念是很重要的。OpenCL基于主机和设备的模型,主机负责程序控制和数据管理,而设备则负责并行计算。掌握这一基本概念是学习OpenCL的第一步。 接下来,需要安装OpenCL的开发环境。在Windows上,可以通过下载和安装OpenCL SDK来获得所需的工具和库文件。在Linux和Mac上,通常可以使用系统自带的OpenCL实现。 然后,调研OpenCL编程模型OpenCL使用基于C语言的编程模型,使用特定的语法和关键字来实现并行计算。学习如何编写和运行OpenCL内核函数非常重要,内核函数是在设备上执行的并行计算任务。 进一步,了解OpenCL中的并行计算模型OpenCL提供了不同的并行计算模式,如单指令多数据(SIMD)和单指令多线程(SIMT)。学习如何使用这些模式可以优化程序的性能。 此外,学习如何处理内存管理和数据传输也是非常重要的。OpenCL使用不同类型的内存来存储和传输数据,包括全局内存、常量内存和本地内存。了解如何在主机和设备之间传输数据是编写高效程序的关键。 最后,探索OpenCL的高级功能。OpenCL提供了许多高级功能,如图像处理和多设备共享内存。了解这些功能可以进一步提高程序的性能和灵活性。 总之,学习OpenCL需要对其基本概念、编程模型并行计算模式和内存管理等方面有全面的了解。通过实践和深入的学习,可以掌握OpenCL并在并行计算领域中发挥其潜力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值