Reputation: 11
I try to run a program on my Intel CPU. I use the actual Intel SDK and it compiles and works till the point, where it should create a context. This is the Output of the program:
===== 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.
And this is the code, that makes the problem.
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;
}
Why does OpenCL says, that the device is available, but fails with "device unavailible" when it should create a context?
Upvotes: 1
Views: 3726
Reputation: 2565
So a possible explanation could be that it's due to the Intel SDK as explained in that post. To quote the main idea:
Intel OpenCL CPU needs at least SSE 4.1. The Core 2 Duo only goes up to SSSE3.
The solution given was:
Install the AMD OpenCL CPU driver. It only needs SSE2.
Upvotes: 3
Reputation: 8036
Instead of using clCreateContextFromType()
, just use clCreateContext()
and pass it the device id of the CPU device returned from clGetDeviceIDs()
.
Upvotes: 0