aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/opencl
diff options
context:
space:
mode:
Diffstat (limited to 'vcpkg/ports/opencl')
-rw-r--r--vcpkg/ports/opencl/001-remove-extra-install-rules.patch36
-rw-r--r--vcpkg/ports/opencl/icd-loader-pkgconfig.diff64
-rw-r--r--vcpkg/ports/opencl/portfile.cmake92
-rw-r--r--vcpkg/ports/opencl/usage30
-rw-r--r--vcpkg/ports/opencl/vcpkg-cmake-wrapper.cmake21
-rw-r--r--vcpkg/ports/opencl/vcpkg.json19
6 files changed, 262 insertions, 0 deletions
diff --git a/vcpkg/ports/opencl/001-remove-extra-install-rules.patch b/vcpkg/ports/opencl/001-remove-extra-install-rules.patch
new file mode 100644
index 0000000..4b212f9
--- /dev/null
+++ b/vcpkg/ports/opencl/001-remove-extra-install-rules.patch
@@ -0,0 +1,36 @@
+diff --git a/lib/CMakeLists.txt b/lib/CMakeLists.txt
+index dfb336d..ef97f82 100644
+--- a/lib/CMakeLists.txt
++++ b/lib/CMakeLists.txt
+@@ -114,13 +114,6 @@ foreach(UTIL_LIB_NAME IN ITEMS Utils UtilsCpp)
+ DESTINATION ${config_package_location}
+ COMPONENT binary
+ )
+-
+- # For packaging the utils libraries
+- install(
+- TARGETS ${UTIL_LIB_TARGET}
+- DESTINATION ${CMAKE_INSTALL_LIBDIR}
+- COMPONENT binary
+- )
+ endforeach()
+
+ if(OPENCL_SDK_BUILD_SAMPLES)
+diff --git a/lib/src/Extensions/CMakeLists.txt b/lib/src/Extensions/CMakeLists.txt
+index e05d4e7..017f7ad 100644
+--- a/lib/src/Extensions/CMakeLists.txt
++++ b/lib/src/Extensions/CMakeLists.txt
+@@ -151,13 +151,6 @@ if (OPENCL_EXTENSION_LOADER_INSTALL)
+ DESTINATION ${OPENCL_EXTENSION_LOADER_CONFIG_PATH}
+ COMPONENT binary
+ )
+-
+- # For packaging the extensions library
+- install(
+- TARGETS OpenCLExt
+- DESTINATION ${CMAKE_INSTALL_LIBDIR}
+- COMPONENT binary
+- )
+ endif()
+
+ if (CMAKE_PROJECT_NAME STREQUAL PROJECT_NAME AND BUILD_TESTING)
diff --git a/vcpkg/ports/opencl/icd-loader-pkgconfig.diff b/vcpkg/ports/opencl/icd-loader-pkgconfig.diff
new file mode 100644
index 0000000..93e6cad
--- /dev/null
+++ b/vcpkg/ports/opencl/icd-loader-pkgconfig.diff
@@ -0,0 +1,64 @@
+diff --git a/CMakeLists.txt b/CMakeLists.txt
+index a1617d0..1bbcafb 100644
+--- a/CMakeLists.txt
++++ b/CMakeLists.txt
+@@ -125,6 +125,7 @@ set_target_properties (OpenCL PROPERTIES VERSION 1\.0\.0 SOVERSION "1")
+
+ if (WIN32)
+ target_link_libraries (OpenCL PRIVATE cfgmgr32.lib runtimeobject.lib)
++ string(APPEND OPENCL_LIBS_PRIVATE_PC " -lcfgmgr32 -lruntimeobject")
+
+ # Generate a DLL without a "lib" prefix for mingw.
+ if (MINGW OR MSYS OR CYGWIN)
+@@ -133,6 +134,7 @@ if (WIN32)
+ endif()
+ else()
+ target_link_libraries (OpenCL PRIVATE ${CMAKE_THREAD_LIBS_INIT})
++ string(APPEND OPENCL_LIBS_PRIVATE_PC " ${CMAKE_THREAD_LIBS_INIT}")
+ if (NOT APPLE)
+ set_target_properties (OpenCL PROPERTIES LINK_FLAGS "-Wl,--version-script -Wl,${CMAKE_CURRENT_SOURCE_DIR}/loader/linux/icd_exports.map")
+ if (OPENCL_ICD_LOADER_PIC)
+@@ -174,6 +176,9 @@ target_include_directories (OpenCL
+ loader
+ )
+ target_link_libraries (OpenCL PUBLIC ${CMAKE_DL_LIBS})
++if(CMAKE_DL_LIBS STREQUAL "dl")
++ string(APPEND OPENCL_LIBS_PRIVATE_PC " -ldl")
++endif()
+
+ if (ENABLE_OPENCL_LAYERINFO)
+
+@@ -294,3 +299,4 @@ install (TARGETS OpenCL
+ DESTINATION ${CMAKE_INSTALL_LIBDIR}
+ COMPONENT dev
+ NAMELINK_ONLY)
++install_opencl_pc()
+diff --git a/OpenCL.pc.in b/OpenCL.pc.in
+index ef35333..b86da22 100644
+--- a/OpenCL.pc.in
++++ b/OpenCL.pc.in
+@@ -7,3 +7,4 @@ Description: Khronos OpenCL ICD Loader
+ Requires: OpenCL-Headers
+ Version: 3.0
+ Libs: -L${libdir} -lOpenCL
++Libs.private:@OPENCL_LIBS_PRIVATE_PC@
+diff --git a/cmake/Package.cmake b/cmake/Package.cmake
+index adfa505..e1d0e1f 100644
+--- a/cmake/Package.cmake
++++ b/cmake/Package.cmake
+@@ -12,6 +12,7 @@ join_paths(OPENCL_LIBDIR_PC "\${exec_prefix}" "${CMAKE_INSTALL_LIBDIR}")
+ set(pkg_config_location ${CMAKE_INSTALL_LIBDIR}/pkgconfig)
+ set(PKGCONFIG_PREFIX "${CMAKE_INSTALL_PREFIX}")
+
++function(install_opencl_pc)
+ # Configure and install OpenCL.pc for installing the project
+ configure_file(
+ OpenCL.pc.in
+@@ -34,6 +35,7 @@ install(
+ DESTINATION ${pkg_config_location}
+ COMPONENT dev
+ EXCLUDE_FROM_ALL)
++endfunction()
+
+ set(CPACK_DEBIAN_PACKAGE_DEBUG ON)
+
diff --git a/vcpkg/ports/opencl/portfile.cmake b/vcpkg/ports/opencl/portfile.cmake
new file mode 100644
index 0000000..2f20b21
--- /dev/null
+++ b/vcpkg/ports/opencl/portfile.cmake
@@ -0,0 +1,92 @@
+vcpkg_from_github(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO KhronosGroup/OpenCL-SDK
+ REF "v${VERSION}"
+ SHA512 be396a7aad6251d9d1f1af265ecf20f3428d87610d680c14d92fb5b060a59ce8b8522135a0dd29eaf20e75683e45c1c8ea55035a7c3ec3eddc4bc7680d68b66e
+ HEAD_REF main
+ PATCHES
+ # see https://github.com/KhronosGroup/OpenCL-SDK/pull/88/files#r1905072265
+ 001-remove-extra-install-rules.patch
+)
+
+vcpkg_from_github(
+ OUT_SOURCE_PATH OPENCL_HEADERS
+ REPO KhronosGroup/OpenCL-Headers
+ REF "v${VERSION}"
+ SHA512 9d2ed2a8346bc3f967989091d8cc36148ffe5ff13fe30e12354cc8321c09328bbe23e74817526b99002729c884438a3b1834e175a271f6d36e8341fd86fc1ad5
+ HEAD_REF main
+)
+if(NOT EXISTS "${SOURCE_PATH}/external/OpenCL-Headers/CMakeLists.txt")
+ file(REMOVE_RECURSE "${SOURCE_PATH}/external/OpenCL-Headers")
+ file(RENAME "${OPENCL_HEADERS}" "${SOURCE_PATH}/external/OpenCL-Headers")
+endif()
+
+vcpkg_from_github(
+ OUT_SOURCE_PATH OPENCL_CLHPP
+ REPO KhronosGroup/OpenCL-CLHPP
+ REF "v${VERSION}"
+ SHA512 7cdadc8ef182d1556346bd34b5a9ffe6e239ab61ec527e5609d69e1bcaf81a88f3fc534f5bdeed037236e1b0e61f1544d2a95c06df55f9cd8e03e13baf4143ba
+ HEAD_REF main
+)
+if(NOT EXISTS "${SOURCE_PATH}/external/OpenCL-CLHPP/CMakeLists.txt")
+ file(REMOVE_RECURSE "${SOURCE_PATH}/external/OpenCL-CLHPP")
+ file(RENAME "${OPENCL_CLHPP}" "${SOURCE_PATH}/external/OpenCL-CLHPP")
+endif()
+
+vcpkg_from_github(
+ OUT_SOURCE_PATH OPENCL_ICD_LOADER
+ REPO KhronosGroup/OpenCL-ICD-Loader
+ REF "v${VERSION}"
+ SHA512 29043eff21076440046314edf62bb488b7e4e17d9fbdac4c3727d8e2523c0c8fbf89ee7fcf762528af761ddbcb4be24e5f062ffa82f778401d6365faa35344a8
+ HEAD_REF main
+ PATCHES
+ icd-loader-pkgconfig.diff
+)
+if(NOT EXISTS "${SOURCE_PATH}/external/OpenCL-ICD-Loader/CMakeLists.txt")
+ file(REMOVE_RECURSE "${SOURCE_PATH}/external/OpenCL-ICD-Loader")
+ file(RENAME "${OPENCL_ICD_LOADER}" "${SOURCE_PATH}/external/OpenCL-ICD-Loader")
+endif()
+
+vcpkg_from_github(
+ OUT_SOURCE_PATH WHEREAMI
+ REPO gpakosz/whereami
+ REF f5e3eac441acbb4ec1fe3e2c32646248ae463398 # 2024-06-09
+ SHA512 d6fa8b6788cabdbb185a6ffba79c994762924a1c60595b769a7d3bb4a3ddf0f80cdeac7bd915cffa720f9123a720a1b7f0023fd7f2cf58906d15758529a99e2d
+ HEAD_REF master
+)
+
+vcpkg_cmake_configure(
+ SOURCE_PATH "${SOURCE_PATH}"
+ OPTIONS
+ "-DFETCHCONTENT_SOURCE_DIR_WHEREAMI-EXTERNAL=${WHEREAMI}"
+ -DBUILD_DOCS=OFF
+ -DBUILD_EXAMPLES=OFF
+ -DBUILD_TESTING=OFF
+ -DOPENCL_HEADERS_BUILD_CXX_TESTS=OFF
+ -DOPENCL_SDK_BUILD_SAMPLES=OFF
+)
+vcpkg_cmake_install()
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCLHeaders" PACKAGE_NAME "OpenCLHeaders" DO_NOT_DELETE_PARENT_CONFIG_PATH)
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCLICDLoader" PACKAGE_NAME "OpenCLICDLoader" DO_NOT_DELETE_PARENT_CONFIG_PATH)
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCLHeadersCpp" PACKAGE_NAME "OpenCLHeadersCpp" DO_NOT_DELETE_PARENT_CONFIG_PATH)
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCLUtils" PACKAGE_NAME "OpenCLUtils" DO_NOT_DELETE_PARENT_CONFIG_PATH)
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCLUtilsCpp" PACKAGE_NAME "OpenCLUtilsCpp" DO_NOT_DELETE_PARENT_CONFIG_PATH)
+vcpkg_cmake_config_fixup(CONFIG_PATH "share/cmake/OpenCL" PACKAGE_NAME "opencl")
+vcpkg_fixup_pkgconfig()
+vcpkg_copy_pdbs()
+vcpkg_copy_tools(TOOL_NAMES cllayerinfo AUTO_CLEAN)
+
+file(REMOVE_RECURSE
+ "${CURRENT_PACKAGES_DIR}/debug/include"
+ "${CURRENT_PACKAGES_DIR}/debug/share"
+)
+
+configure_file("${CMAKE_CURRENT_LIST_DIR}/vcpkg-cmake-wrapper.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/vcpkg-cmake-wrapper.cmake" @ONLY)
+
+file(COPY "${CMAKE_CURRENT_LIST_DIR}/usage" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}")
+vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/LICENSE" "${WHEREAMI}/LICENSE.MIT"
+ COMMENT [[
+The OpenCL SDK is licensed under the terms of the Apache-2.0 license.
+The OpenCL Utility Library uses code from https://github.com/gpakosz/whereami
+which is dual licensed under both the WTFPLv2 and MIT licenses.
+]])
diff --git a/vcpkg/ports/opencl/usage b/vcpkg/ports/opencl/usage
new file mode 100644
index 0000000..38570b2
--- /dev/null
+++ b/vcpkg/ports/opencl/usage
@@ -0,0 +1,30 @@
+opencl provides CMake targets:
+
+ find_package(OpenCL CONFIG REQUIRED)
+
+ # Khronos OpenCL ICD Loader
+ target_link_libraries(main PRIVATE OpenCL::OpenCL)
+
+ # Khronos OpenCL Headers and C++ bindings
+ target_link_libraries(main PRIVATE OpenCL::Headers)
+ target_link_libraries(main PRIVATE OpenCL::HeadersCpp)
+
+ # OpenCL Utility Library and C++ bindings
+ target_link_libraries(main PRIVATE OpenCL::Utils)
+ target_link_libraries(main PRIVATE OpenCL::UtilsCpp)
+
+opencl provides pkg-config modules:
+
+ # Khronos OpenCL ICD Loader
+ OpenCL
+
+ # Khronos OpenCL Headers and C++ bindings
+ OpenCL-Headers
+ OpenCL-CLHPP
+
+This package is only an OpenCL SDK. To actually run OpenCL code you also need to install an implementation.
+
+ Windows: Implementations typically ship with the drivers of you CPU/GPU vendors.
+ Linux: Implementations may be installed from your distro's repo or manually.
+ Apple: Consult your distribution vendor on the state of OpenCL support:
+ https://support.apple.com/en-us/HT202823
diff --git a/vcpkg/ports/opencl/vcpkg-cmake-wrapper.cmake b/vcpkg/ports/opencl/vcpkg-cmake-wrapper.cmake
new file mode 100644
index 0000000..04fca75
--- /dev/null
+++ b/vcpkg/ports/opencl/vcpkg-cmake-wrapper.cmake
@@ -0,0 +1,21 @@
+string(FIND ";${ARGS};" ";CONFIG;" z_vcpkg_opencl_config)
+_find_package(${ARGS})
+if("@VCPKG_LIBRARY_LINKAGE@" STREQUAL "static" AND (NOT CMAKE_SYSTEM_NAME MATCHES "Darwin") AND z_vcpkg_opencl_config EQUAL "-1")
+ find_package(Threads REQUIRED)
+ set(OpenCL_Extra_Libs ${CMAKE_DL_LIBS} ${CMAKE_THREAD_LIBS_INIT})
+ if(CMAKE_SYSTEM_NAME MATCHES "Windows")
+ list(APPEND OpenCL_Extra_Libs cfgmgr32)
+ if("$ENV{WindowsSDKVersion}" MATCHES "^10")
+ list(APPEND OpenCL_Extra_Libs OneCoreUAP)
+ endif()
+ endif()
+
+ if(TARGET OpenCL::OpenCL)
+ set_property(TARGET OpenCL::OpenCL APPEND PROPERTY INTERFACE_LINK_LIBRARIES ${OpenCL_Extra_Libs})
+ endif()
+ if(OpenCL_LIBRARIES)
+ list(APPEND OpenCL_LIBRARIES ${OpenCL_Extra_Libs})
+ endif()
+ unset(OpenCL_Extra_Libs)
+endif()
+unset(z_vcpkg_opencl_config)
diff --git a/vcpkg/ports/opencl/vcpkg.json b/vcpkg/ports/opencl/vcpkg.json
new file mode 100644
index 0000000..66f4c0e
--- /dev/null
+++ b/vcpkg/ports/opencl/vcpkg.json
@@ -0,0 +1,19 @@
+{
+ "name": "opencl",
+ "version": "2024.10.24",
+ "port-version": 1,
+ "description": "OpenCL SDK",
+ "homepage": "https://github.com/KhronosGroup/OpenCL-SDK",
+ "license": "Apache-2.0 AND (MIT OR WTFPL)",
+ "supports": "!uwp",
+ "dependencies": [
+ {
+ "name": "vcpkg-cmake",
+ "host": true
+ },
+ {
+ "name": "vcpkg-cmake-config",
+ "host": true
+ }
+ ]
+}