c++ - 设备说它可用,但无法在 OpenCL 中创建上下文

标签 c++ c opencl intel

我尝试在我的 Intel CPU 上运行一个程序。我使用实际的英特尔 SDK,它编译并工作到应该创建上下文的地步。这是程序的输出:

=====  Platform 0 =====
PROFILE = FULL_PROFILE
VERSION = OpenCL 1.2 LINUX
NAME = Intel(R) OpenCL
VENDOR = Intel(R) Corporation
VENDOR = cl_khr_fp64 cl_khr_icd cl_khr_global_int32_base_atomics        cl_khr_global_int32_extended_atomics cl_khr_local_int32_base_atomics cl_khr_local_int32_extended_atomics cl_khr_byte_addressable_store cl_intel_printf cl_ext_device_fission cl_intel_exec_by_local_thread 
=== 1 OpenCL device(s) found on platform: 0

=== --- Device -- 0 
DEVICE_NAME = Intel(R) Core(TM)2 Duo CPU     P8400  @ 2.26GHz
DEVICE_VENDOR = Intel(R) Corporation
DEVICE_VERSION = OpenCL 1.2 (Build 67279)
DRIVER_VERSION = 1.2
DEVICE_MAX_COMPUTE_UNITS = 2
DEVICE_MAX_CLOCK_FREQUENCY = 2260
DEVICE_GLOBAL_MEM_SIZE = 4035719168

DEVICE_AVAILABLE = Yes

Unable to create GPU or CPU context
CL_DEVICE_NOT_AVAILABLE
unable to create context. Abort.

这是导致问题的代码。

cl_context CTrainMLP_CreateContext(){
cl_int errNum;
cl_uint numPlatforms;
cl_platform_id firstPlatformId;
cl_context context=NULL;
cl_device_id device;
//get Platform and choose first one
errNum = clGetPlatformIDs(1,&firstPlatformId, &numPlatforms);
if(errNum != CL_SUCCESS || numPlatforms<=0){
cerr<<"No OpenCL platforum found!"<<endl;
return NULL;
}

char buffer[10240];
printf("=====  Platform 0 =====\n");
clGetPlatformInfo(firstPlatformId,CL_PLATFORM_PROFILE,10240, buffer,NULL);
printf("  PROFILE = %s\n", buffer);
clGetPlatformInfo(firstPlatformId,CL_PLATFORM_VERSION,10240, buffer,NULL);
printf("  VERSION = %s\n", buffer);
clGetPlatformInfo(firstPlatformId,CL_PLATFORM_NAME,10240, buffer,NULL);
printf("  NAME = %s\n", buffer);
clGetPlatformInfo(firstPlatformId,CL_PLATFORM_VENDOR,10240, buffer,NULL);
printf("  VENDOR = %s\n", buffer);
clGetPlatformInfo(firstPlatformId,CL_PLATFORM_EXTENSIONS,10240, buffer,NULL);
printf("  VENDOR = %s\n", buffer);
//  clGetPlatformInfo(platforms[i],CL_PLATFORM_EXTENSIONS,10240,buffer,NULL);
//  printf("  EXTENSIONS = %s\n", buffer);

cl_uint devices_n;

// get the GPU-devices of platform i, print details of the device
errNum = clGetDeviceIDs( firstPlatformId, CL_DEVICE_TYPE_CPU, 1, &device, 
    &devices_n);
if (errNum != CL_SUCCESS)
  printf("error getting device IDS\n");
printf("  === %d OpenCL device(s) found on platform: 0\n\n", devices_n);
for (unsigned int d=0; d<devices_n; d++)
{
  char buffer[10240];
  cl_uint buf_uint;
  cl_ulong buf_ulong;
  cl_bool buf_bool;
  printf("  === --- Device -- %d \n", d);
  (clGetDeviceInfo(device, CL_DEVICE_NAME, sizeof(buffer), 
       buffer, NULL));
  printf("    DEVICE_NAME = %s\n", buffer);
  (clGetDeviceInfo(device, CL_DEVICE_VENDOR, sizeof(buffer), 
       buffer, NULL));
  printf("    DEVICE_VENDOR = %s\n", buffer);
  (clGetDeviceInfo(device, CL_DEVICE_VERSION, sizeof(buffer), 
       buffer, NULL));
  printf("    DEVICE_VERSION = %s\n", buffer);
  (clGetDeviceInfo(device, CL_DRIVER_VERSION, sizeof(buffer), 
       buffer, NULL));
  printf("    DRIVER_VERSION = %s\n", buffer);
  (clGetDeviceInfo(device, CL_DEVICE_MAX_COMPUTE_UNITS, 
       sizeof(buf_uint), &buf_uint, NULL));
  printf("    DEVICE_MAX_COMPUTE_UNITS = %u\n", (unsigned int)buf_uint);
  (clGetDeviceInfo(device, CL_DEVICE_MAX_CLOCK_FREQUENCY, 
       sizeof(buf_uint), &buf_uint, NULL));
  printf("    DEVICE_MAX_CLOCK_FREQUENCY = %u\n", (unsigned int)buf_uint);
  (clGetDeviceInfo(device, CL_DEVICE_GLOBAL_MEM_SIZE, 
       sizeof(buf_ulong), &buf_ulong, NULL));
  printf("    DEVICE_GLOBAL_MEM_SIZE = %u\n\n", (unsigned int)buf_ulong);
  (clGetDeviceInfo(device, CL_DEVICE_AVAILABLE, 
       sizeof(buf_bool), &buf_bool, NULL));
  printf("    DEVICE_AVAILABLE = %s\n\n", buf_bool?"Yes":"No");
}
if (devices_n == 0)
{
  printf("error, on platform 0, there is no GPU device\n");
}

cl_context_properties contextProperties[3]={
  CL_CONTEXT_PLATFORM,
  (cl_context_properties)firstPlatformId,
  0
};
  context = clCreateContextFromType(contextProperties,       CL_DEVICE_TYPE_ALL,NULL,NULL,&errNum);
 if (errNum!= CL_SUCCESS){
  cerr<<"Unable to create GPU or CPU context"<<endl;
  check_error(errNum);
  return NULL;
 }
cout<<"Created CPU context"<<endl;
return context;
}

为什么 OpenCL 说设备可用,但在应该创建上下文时失败并显示“设备不可用”?

最佳答案

所以可能的解释是,这是由于英特尔 SDK 造成的,如 post 中所述。 .引用主要思想:

Intel OpenCL CPU needs at least SSE 4.1. The Core 2 Duo only goes up to SSSE3.

给出的解决方案是:

Install the AMD OpenCL CPU driver. It only needs SSE2.

关于c++ - 设备说它可用,但无法在 OpenCL 中创建上下文,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17346647/

相关文章:

C++ 如何将 boost 库与我的共享库链接以在目标机器上工作?

c - dup2、C 中的管道和 fork

java - 在LWJGL的OpenCL功能中,我从哪里得出 "cl_platform_id"?

python - Python 中的 GPGPU 编程

C++ VirtualProtect PAGE_NOACCESS 导致崩溃

C++ 在模板中使用运算符关键字?

android - 创建一个 C++ 类并在另一个包含 ndk android 中的 JNI 方法的 C++ 类中使用该类

c - 根据位掩码合并两个位域

c - 计算后缀表达式时出现不需要的符号结果

xcode - Intel HD Graphics 4000 和 Nvidia GeForce GT 650M 上的 openCL 无法工作 : CL_INVALID_DEVICE error