mirror of https://github.com/BOINC/boinc.git
- client: prevent client from crashing in OpenCL code
- client: fix function prototypes for dynamically calling OpenCL functions. client/ coproc_detect.cpp svn path=/trunk/boinc/; revision=23292
This commit is contained in:
parent
1fddbea7d6
commit
44dc2df81d
|
@ -1922,3 +1922,11 @@ Charlie 29 Mar 2011
|
||||||
coproc_detect.cpp
|
coproc_detect.cpp
|
||||||
lib/
|
lib/
|
||||||
coproc.cpp.h
|
coproc.cpp.h
|
||||||
|
|
||||||
|
Rom 29 Mar 2011
|
||||||
|
- client: prevent client from crashing in OpenCL code
|
||||||
|
- client: fix function prototypes for dynamically calling
|
||||||
|
OpenCL functions.
|
||||||
|
|
||||||
|
client/
|
||||||
|
coproc_detect.cpp
|
||||||
|
|
|
@ -64,13 +64,13 @@ void segv_handler(int) {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
|
||||||
HMODULE opencl_lib = NULL;
|
HMODULE opencl_lib = NULL;
|
||||||
|
|
||||||
// TODO: Are these correct?
|
|
||||||
typedef cl_int (__stdcall *CL_PLATFORMIDS) (cl_uint, cl_platform_id*, cl_uint*);
|
typedef cl_int (__stdcall *CL_PLATFORMIDS) (cl_uint, cl_platform_id*, cl_uint*);
|
||||||
typedef cl_int (__stdcall *CL_PLATFORMINFO) (cl_platform_id, cl_platform_info, size_t, void*, size_t*);
|
typedef cl_int (__stdcall *CL_PLATFORMINFO) (cl_platform_id, cl_platform_info, size_t, void*, size_t*);
|
||||||
typedef cl_int (__stdcall *CL_DEVICEIDS)(cl_platform_id, cl_device_type, cl_uint, cl_device_id*, cl_uint*);
|
typedef cl_int (__stdcall *CL_DEVICEIDS)(cl_platform_id, cl_device_type, cl_uint, cl_device_id*, cl_uint*);
|
||||||
typedef int (__stdcall *CL_INFO) (cl_device_id, cl_device_info, size_t, void*, size_t*);
|
typedef cl_int (__stdcall *CL_INFO) (cl_device_id, cl_device_info, size_t, void*, size_t*);
|
||||||
|
|
||||||
CL_PLATFORMIDS __clGetPlatformIDs = NULL;
|
CL_PLATFORMIDS __clGetPlatformIDs = NULL;
|
||||||
CL_PLATFORMINFO __clGetPlatformInfo = NULL;
|
CL_PLATFORMINFO __clGetPlatformInfo = NULL;
|
||||||
|
@ -171,6 +171,8 @@ void COPROCS::get_opencl(bool use_all, vector<string>&warnings) {
|
||||||
cl_uint num_platforms, num_devices, device_index;
|
cl_uint num_platforms, num_devices, device_index;
|
||||||
cl_device_id devices[MAX_COPROC_INSTANCES];
|
cl_device_id devices[MAX_COPROC_INSTANCES];
|
||||||
OPENCL_DEVICE_PROP prop;
|
OPENCL_DEVICE_PROP prop;
|
||||||
|
vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
||||||
|
vector<OPENCL_DEVICE_PROP> ati_opencls;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
@ -184,9 +186,7 @@ void COPROCS::get_opencl(bool use_all, vector<string>&warnings) {
|
||||||
__clGetPlatformInfo = (CL_PLATFORMINFO)( opencl_lib, "clGetPlatformInfo" );
|
__clGetPlatformInfo = (CL_PLATFORMINFO)( opencl_lib, "clGetPlatformInfo" );
|
||||||
__clGetDeviceIDs = (CL_DEVICEIDS)GetProcAddress( opencl_lib, "clGetDeviceIDs" );
|
__clGetDeviceIDs = (CL_DEVICEIDS)GetProcAddress( opencl_lib, "clGetDeviceIDs" );
|
||||||
__clGetDeviceInfo = (CL_INFO)GetProcAddress( opencl_lib, "clGetDeviceInfo" );
|
__clGetDeviceInfo = (CL_INFO)GetProcAddress( opencl_lib, "clGetDeviceInfo" );
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
opencl_lib = dlopen("/System/Library/Frameworks/OpenCL.framework/Versions/Current/OpenCL", RTLD_NOW);
|
opencl_lib = dlopen("/System/Library/Frameworks/OpenCL.framework/Versions/Current/OpenCL", RTLD_NOW);
|
||||||
#else
|
#else
|
||||||
|
@ -202,10 +202,15 @@ void COPROCS::get_opencl(bool use_all, vector<string>&warnings) {
|
||||||
__clGetDeviceIDs = (cl_int(*)(cl_platform_id, cl_device_type, cl_uint, cl_device_id*, cl_uint*)) dlsym( opencl_lib, "clGetDeviceIDs" );
|
__clGetDeviceIDs = (cl_int(*)(cl_platform_id, cl_device_type, cl_uint, cl_device_id*, cl_uint*)) dlsym( opencl_lib, "clGetDeviceIDs" );
|
||||||
__clGetDeviceInfo = (cl_int(*)(cl_device_id, cl_device_info, size_t, void*, size_t*)) dlsym( opencl_lib, "clGetDeviceInfo" );
|
__clGetDeviceInfo = (cl_int(*)(cl_device_id, cl_device_info, size_t, void*, size_t*)) dlsym( opencl_lib, "clGetDeviceInfo" );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!__clGetPlatformIDs) {
|
if (!__clGetPlatformIDs) {
|
||||||
warnings.push_back("clGetPlatformIDs() missing from OpenCL library");
|
warnings.push_back("clGetPlatformIDs() missing from OpenCL library");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (!__clGetPlatformInfo) {
|
||||||
|
warnings.push_back("clGetPlatformInfo() missing from OpenCL library");
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (!__clGetDeviceIDs) {
|
if (!__clGetDeviceIDs) {
|
||||||
warnings.push_back("clGetDeviceIDs() missing from OpenCL library");
|
warnings.push_back("clGetDeviceIDs() missing from OpenCL library");
|
||||||
return;
|
return;
|
||||||
|
@ -222,21 +227,21 @@ void COPROCS::get_opencl(bool use_all, vector<string>&warnings) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
ciErrNum = (*__clGetDeviceIDs)(platforms[0], CL_DEVICE_TYPE_GPU, MAX_COPROC_INSTANCES, devices, &num_devices);
|
ciErrNum = (*__clGetDeviceIDs)(
|
||||||
|
platforms[0], CL_DEVICE_TYPE_GPU, MAX_COPROC_INSTANCES, devices, &num_devices
|
||||||
|
);
|
||||||
if ((ciErrNum != CL_SUCCESS) || (num_devices == 0)) {
|
if ((ciErrNum != CL_SUCCESS) || (num_devices == 0)) {
|
||||||
warnings.push_back("OpenCL library present but no GPUs found");
|
warnings.push_back("OpenCL library present but no GPUs found");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
vector<OPENCL_DEVICE_PROP> nvidia_opencls;
|
|
||||||
vector<OPENCL_DEVICE_PROP> ati_opencls;
|
|
||||||
|
|
||||||
for (device_index=0; device_index<num_devices; ++device_index) {
|
for (device_index=0; device_index<num_devices; ++device_index) {
|
||||||
memset(&prop, 0, sizeof(prop));
|
memset(&prop, 0, sizeof(prop));
|
||||||
prop.device_id = devices[device_index];
|
prop.device_id = devices[device_index];
|
||||||
|
|
||||||
ciErrNum = (*__clGetPlatformInfo) (platforms[0], CL_PLATFORM_VERSION, sizeof(prop.openCL_platform_version),
|
ciErrNum = (*__clGetPlatformInfo)(
|
||||||
prop.openCL_platform_version, NULL);
|
platforms[0], CL_PLATFORM_VERSION, sizeof(prop.openCL_platform_version), prop.openCL_platform_version, NULL
|
||||||
|
);
|
||||||
if (ciErrNum != CL_SUCCESS) {
|
if (ciErrNum != CL_SUCCESS) {
|
||||||
warnings.push_back("clGetPlatformInfo() failed to get platform version");
|
warnings.push_back("clGetPlatformInfo() failed to get platform version");
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in New Issue