diff options
| author | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
|---|---|---|
| committer | Ethan Morgan <ethan@gweithio.com> | 2026-02-14 16:44:06 +0000 |
| commit | 54409423f767d8b1cf30cb7d0efca6b4ca138823 (patch) | |
| tree | d915ac7828703ce4b963efdd9728a1777ba18c1e /vcpkg/ports/opencl | |
Diffstat (limited to 'vcpkg/ports/opencl')
| -rw-r--r-- | vcpkg/ports/opencl/001-remove-extra-install-rules.patch | 36 | ||||
| -rw-r--r-- | vcpkg/ports/opencl/icd-loader-pkgconfig.diff | 64 | ||||
| -rw-r--r-- | vcpkg/ports/opencl/portfile.cmake | 92 | ||||
| -rw-r--r-- | vcpkg/ports/opencl/usage | 30 | ||||
| -rw-r--r-- | vcpkg/ports/opencl/vcpkg-cmake-wrapper.cmake | 21 | ||||
| -rw-r--r-- | vcpkg/ports/opencl/vcpkg.json | 19 |
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 + } + ] +} |