bare skeleton created
This commit is contained in:
commit
d59e3d4ee2
3
.gitignore
vendored
Normal file
3
.gitignore
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
*.o
|
||||||
|
build
|
||||||
|
*.user
|
15
CMakeLists.txt
Normal file
15
CMakeLists.txt
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
cmake_minimum_required(VERSION 2.8)
|
||||||
|
|
||||||
|
set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cmake")
|
||||||
|
project(opencl-test)
|
||||||
|
find_package(OpenCL REQUIRED)
|
||||||
|
|
||||||
|
message(STATUS "OpenCL found: ${OPENCL_FOUND}")
|
||||||
|
message(STATUS "OpenCL includes: ${OPENCL_INCLUDE_DIRS}")
|
||||||
|
message(STATUS "OpenCL CXX includes: ${OPENCL_HAS_CPP_BINDINGS}")
|
||||||
|
message(STATUS "OpenCL libraries: ${OPENCL_LIBRARIES}")
|
||||||
|
|
||||||
|
add_executable(${PROJECT_NAME} "main.cpp")
|
||||||
|
|
||||||
|
target_link_libraries(${PROJECT_NAME} ${OPENCL_LIBRARIES})
|
||||||
|
include_directories(${PROJECT_NAME} ${OPENCL_INCLUDE_DIR})
|
171
cmake/FindOpenCL.cmake
Normal file
171
cmake/FindOpenCL.cmake
Normal file
@ -0,0 +1,171 @@
|
|||||||
|
# Find OpenCL
|
||||||
|
#
|
||||||
|
# To set manually the paths, define these environment variables:
|
||||||
|
# OpenCL_INCPATH - Include path (e.g. OpenCL_INCPATH=/opt/cuda/4.0/cuda/include)
|
||||||
|
# OpenCL_LIBPATH - Library path (e.h. OpenCL_LIBPATH=/usr/lib64/nvidia)
|
||||||
|
#
|
||||||
|
# Once done this will define
|
||||||
|
# OPENCL_FOUND - system has OpenCL
|
||||||
|
# OPENCL_INCLUDE_DIRS - the OpenCL include directory
|
||||||
|
# OPENCL_LIBRARIES - link these to use OpenCL
|
||||||
|
# OPENCL_HAS_CPP_BINDINGS - system has also cl.hpp
|
||||||
|
|
||||||
|
FIND_PACKAGE(PackageHandleStandardArgs)
|
||||||
|
|
||||||
|
SET (OPENCL_VERSION_STRING "0.1.0")
|
||||||
|
SET (OPENCL_VERSION_MAJOR 0)
|
||||||
|
SET (OPENCL_VERSION_MINOR 1)
|
||||||
|
SET (OPENCL_VERSION_PATCH 0)
|
||||||
|
|
||||||
|
IF (APPLE)
|
||||||
|
|
||||||
|
# IF OpenCL_LIBPATH is given use it and don't use default path
|
||||||
|
IF (DEFINED ENV{OpenCL_LIBPATH})
|
||||||
|
FIND_LIBRARY(OPENCL_LIBRARIES OpenCL PATHS ENV OpenCL_LIBPATH NO_DEFAULT_PATH)
|
||||||
|
ELSE ()
|
||||||
|
FIND_LIBRARY(OPENCL_LIBRARIES OpenCL DOC "OpenCL lib for OSX")
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
# IF OpenCL_INCPATH is given use it and find for CL/cl.h and OpenCL/cl.h do not try to find default paths
|
||||||
|
IF (DEFINED ENV{OpenCL_INCPATH})
|
||||||
|
FIND_PATH(OPENCL_INCLUDE_DIRS CL/cl.h OpenCL/cl.h PATHS ENV OpenCL_INCPATH NO_DEFAULT_PATH)
|
||||||
|
FIND_PATH(_OPENCL_CPP_INCLUDE_DIRS CL/cl.hpp OpenCL/cl.hpp PATHS ${OPENCL_INCLUDE_DIRS} NO_DEFAULT_PATH)
|
||||||
|
ELSE ()
|
||||||
|
FIND_PATH(OPENCL_INCLUDE_DIRS OpenCL/cl.h DOC "Include for OpenCL on OSX")
|
||||||
|
FIND_PATH(_OPENCL_CPP_INCLUDE_DIRS OpenCL/cl.hpp DOC "Include for OpenCL CPP bindings on OSX")
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
ELSE (APPLE)
|
||||||
|
|
||||||
|
IF (WIN32)
|
||||||
|
|
||||||
|
# Find OpenCL includes and libraries from environment variables provided by vendor
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS)
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS)
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS)
|
||||||
|
|
||||||
|
# Nvidia
|
||||||
|
IF (DEFINED ENV{CUDA_INC_PATH})
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS ${OPENCL_INCLUDE_SEARCH_PATHS} $ENV{CUDA_INC_PATH})
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS ${OPENCL_LIBRARY_64_SEARCH_PATHS} $ENV{CUDA_LIB_PATH}/../lib64)
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS ${OPENCL_LIBRARY_SEARCH_PATHS} $ENV{CUDA_LIB_PATH}/../lib)
|
||||||
|
ENDIF()
|
||||||
|
IF (DEFINED ENV{CUDA_PATH})
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS ${OPENCL_INCLUDE_SEARCH_PATHS} $ENV{CUDA_INC_PATH})
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS ${OPENCL_LIBRARY_64_SEARCH_PATHS} $ENV{CUDA_PATH}/lib/x64/)
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS ${OPENCL_LIBRARY_SEARCH_PATHS} $ENV{CUDA_PATH}/lib/Win32/)
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
|
# Intel SDK
|
||||||
|
IF (DEFINED ENV{INTELOCSDKROOT})
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS ${OPENCL_INCLUDE_SEARCH_PATHS} $ENV{INTELOCSDKROOT}/include)
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS ${OPENCL_LIBRARY_64_SEARCH_PATHS} $ENV{INTELOCSDKROOT}/lib/x64)
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS ${OPENCL_LIBRARY_SEARCH_PATHS} $ENV{INTELOCSDKROOT}/lib/x86)
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
|
# AMD SDK
|
||||||
|
IF (DEFINED ENV{AMDAPPSDKROOT})
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS ${OPENCL_INCLUDE_SEARCH_PATHS} $ENV{AMDAPPSDKROOT}/include)
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS ${OPENCL_LIBRARY_64_SEARCH_PATHS} $ENV{AMDAPPSDKROOT}/lib/x86_64)
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS ${OPENCL_LIBRARY_SEARCH_PATHS} $ENV{AMDAPPSDKROOT}/lib/x86)
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
|
# Override search paths with OpenCL_INCPATH env variable
|
||||||
|
IF (DEFINED ENV{OpenCL_INCPATH})
|
||||||
|
SET(OPENCL_INCLUDE_SEARCH_PATHS $ENV{OpenCL_INCPATH})
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
# Override search paths with OpenCL_LIBPATH env variable
|
||||||
|
IF (DEFINED ENV{OpenCL_LIBPATH})
|
||||||
|
SET(OPENCL_LIBRARY_SEARCH_PATHS $ENV{OpenCL_LIBPATH})
|
||||||
|
SET(OPENCL_LIBRARY_64_SEARCH_PATHS $ENV{OpenCL_LIBPATH})
|
||||||
|
ENDIF ()
|
||||||
|
|
||||||
|
FIND_PATH(OPENCL_INCLUDE_DIRS CL/cl.h PATHS ${OPENCL_INCLUDE_SEARCH_PATHS})
|
||||||
|
FIND_PATH(_OPENCL_CPP_INCLUDE_DIRS CL/cl.hpp PATHS ${OPENCL_INCLUDE_SEARCH_PATHS})
|
||||||
|
|
||||||
|
FIND_LIBRARY(_OPENCL_32_LIBRARIES OpenCL.lib HINTS ${OPENCL_LIBRARY_SEARCH_PATHS} PATHS ${OPENCL_LIB_DIR} ENV PATH)
|
||||||
|
FIND_LIBRARY(_OPENCL_64_LIBRARIES OpenCL.lib HINTS ${OPENCL_LIBRARY_64_SEARCH_PATHS} PATHS ${OPENCL_LIB_DIR} ENV PATH)
|
||||||
|
|
||||||
|
# Check if 64bit or 32bit versions links fine
|
||||||
|
SET (_OPENCL_VERSION_SOURCE "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/openclversion.c")
|
||||||
|
#SET (_OPENCL_VERSION_SOURCE "${CMAKE_BINARY_DIR}/test.c")
|
||||||
|
FILE (WRITE "${_OPENCL_VERSION_SOURCE}"
|
||||||
|
"
|
||||||
|
#if __APPLE__
|
||||||
|
#include <OpenCL/cl.h>
|
||||||
|
#else /* !__APPLE__ */
|
||||||
|
#include <CL/cl.h>
|
||||||
|
#endif /* __APPLE__ */
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
cl_int result;
|
||||||
|
cl_platform_id id;
|
||||||
|
result = clGetPlatformIDs(1, &id, NULL);
|
||||||
|
return result != CL_SUCCESS;
|
||||||
|
}
|
||||||
|
")
|
||||||
|
|
||||||
|
TRY_COMPILE(_OPENCL_64_COMPILE_SUCCESS ${CMAKE_BINARY_DIR} "${_OPENCL_VERSION_SOURCE}"
|
||||||
|
CMAKE_FLAGS
|
||||||
|
"-DINCLUDE_DIRECTORIES:STRING=${OPENCL_INCLUDE_DIRS}"
|
||||||
|
CMAKE_FLAGS
|
||||||
|
"-DLINK_LIBRARIES:STRING=${_OPENCL_64_LIBRARIES}"
|
||||||
|
)
|
||||||
|
|
||||||
|
IF(_OPENCL_64_COMPILE_SUCCESS)
|
||||||
|
message(STATUS "OpenCL 64bit lib found.")
|
||||||
|
SET(OPENCL_LIBRARIES ${_OPENCL_64_LIBRARIES})
|
||||||
|
ELSE()
|
||||||
|
TRY_COMPILE(_OPENCL_32_COMPILE_SUCCESS ${CMAKE_BINARY_DIR} "${_OPENCL_VERSION_SOURCE}"
|
||||||
|
CMAKE_FLAGS
|
||||||
|
"-DINCLUDE_DIRECTORIES:STRING=${OPENCL_INCLUDE_DIRS}"
|
||||||
|
CMAKE_FLAGS
|
||||||
|
"-DLINK_LIBRARIES:STRING=${_OPENCL_32_LIBRARIES}"
|
||||||
|
)
|
||||||
|
IF(_OPENCL_32_COMPILE_SUCCESS)
|
||||||
|
message(STATUS "OpenCL 32bit lib found.")
|
||||||
|
SET(OPENCL_LIBRARIES ${_OPENCL_32_LIBRARIES})
|
||||||
|
ELSE()
|
||||||
|
message(STATUS "Couldn't link opencl..")
|
||||||
|
ENDIF()
|
||||||
|
ENDIF()
|
||||||
|
|
||||||
|
|
||||||
|
ELSE (WIN32)
|
||||||
|
|
||||||
|
IF (CYGWIN)
|
||||||
|
SET (CMAKE_FIND_LIBRARY_SUFFIXES .lib)
|
||||||
|
SET (OCL_LIB_SUFFIX .lib)
|
||||||
|
ENDIF (CYGWIN)
|
||||||
|
|
||||||
|
# Unix style platforms
|
||||||
|
FIND_LIBRARY(OPENCL_LIBRARIES OpenCL${OCL_LIB_SUFFIX}
|
||||||
|
PATHS ENV LD_LIBRARY_PATH ENV OpenCL_LIBPATH
|
||||||
|
)
|
||||||
|
|
||||||
|
GET_FILENAME_COMPONENT(OPENCL_LIB_DIR ${OPENCL_LIBRARIES} PATH)
|
||||||
|
GET_FILENAME_COMPONENT(_OPENCL_INC_CAND ${OPENCL_LIB_DIR}/../../include ABSOLUTE)
|
||||||
|
|
||||||
|
# The AMD SDK currently does not place its headers
|
||||||
|
# in /usr/include, therefore also search relative
|
||||||
|
# to the library
|
||||||
|
FIND_PATH(OPENCL_INCLUDE_DIRS CL/cl.h PATHS ${_OPENCL_INC_CAND} "/usr/local/cuda/include" "/opt/AMDAPP/include" ENV OpenCL_INCPATH)
|
||||||
|
FIND_PATH(_OPENCL_CPP_INCLUDE_DIRS CL/cl.hpp PATHS ${_OPENCL_INC_CAND} "/usr/local/cuda/include" "/opt/AMDAPP/include" ENV OpenCL_INCPATH)
|
||||||
|
|
||||||
|
ENDIF (WIN32)
|
||||||
|
|
||||||
|
ENDIF (APPLE)
|
||||||
|
|
||||||
|
FIND_PACKAGE_HANDLE_STANDARD_ARGS(OpenCL DEFAULT_MSG OPENCL_LIBRARIES OPENCL_INCLUDE_DIRS)
|
||||||
|
|
||||||
|
IF(_OPENCL_CPP_INCLUDE_DIRS)
|
||||||
|
SET( OPENCL_HAS_CPP_BINDINGS TRUE )
|
||||||
|
LIST( APPEND OPENCL_INCLUDE_DIRS ${_OPENCL_CPP_INCLUDE_DIRS} )
|
||||||
|
# This is often the same, so clean up
|
||||||
|
LIST( REMOVE_DUPLICATES OPENCL_INCLUDE_DIRS )
|
||||||
|
ENDIF(_OPENCL_CPP_INCLUDE_DIRS)
|
||||||
|
|
||||||
|
MARK_AS_ADVANCED(
|
||||||
|
OPENCL_INCLUDE_DIRS
|
||||||
|
)
|
43
main.cpp
Normal file
43
main.cpp
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
#include <iostream>
|
||||||
|
#include <vector>
|
||||||
|
#include <CL/cl.h>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
cl_int error;
|
||||||
|
|
||||||
|
cl_uint platformIdCount = 0;
|
||||||
|
clGetPlatformIDs (0, nullptr, &platformIdCount);
|
||||||
|
|
||||||
|
std::vector<cl_platform_id> platformIds (platformIdCount);
|
||||||
|
clGetPlatformIDs (platformIdCount, platformIds.data(), nullptr);
|
||||||
|
|
||||||
|
std::cout << "Platform count: " << platformIdCount << std::endl;
|
||||||
|
|
||||||
|
cl_uint deviceIdCount = 0;
|
||||||
|
clGetDeviceIDs (platformIds [0], CL_DEVICE_TYPE_ALL, 0, nullptr,
|
||||||
|
&deviceIdCount);
|
||||||
|
std::cout << "Device in Platform 0 count: " << deviceIdCount << std::endl;
|
||||||
|
|
||||||
|
std::vector<cl_device_id> deviceIds (deviceIdCount);
|
||||||
|
clGetDeviceIDs (platformIds [0], CL_DEVICE_TYPE_ALL, deviceIdCount,
|
||||||
|
deviceIds.data (), nullptr);
|
||||||
|
|
||||||
|
|
||||||
|
const cl_context_properties contextProperties [] =
|
||||||
|
{
|
||||||
|
CL_CONTEXT_PLATFORM,
|
||||||
|
reinterpret_cast<cl_context_properties> (platformIds [0]),
|
||||||
|
0, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
cl_context context = clCreateContext (
|
||||||
|
contextProperties, deviceIdCount,
|
||||||
|
deviceIds.data (), nullptr,
|
||||||
|
nullptr, &error);
|
||||||
|
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user