commit: 9dfec86d9c630c606c90410b6238a35e99f1a893
Author: Patrick Lauer <patrick <AT> gentoo <DOT> org>
AuthorDate: Mon Oct 13 10:21:15 2025 +0000
Commit: Patrick Lauer <patrick <AT> gentoo <DOT> org>
CommitDate: Mon Oct 13 10:21:26 2025 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=9dfec86d
dev-libs/pocl: add 7.1
Signed-off-by: Patrick Lauer <patrick <AT> gentoo.org>
dev-libs/pocl/Manifest | 1 +
dev-libs/pocl/pocl-7.1.ebuild | 146 ++++++++++++++++++++++++++++++++++++++++++
2 files changed, 147 insertions(+)
diff --git a/dev-libs/pocl/Manifest b/dev-libs/pocl/Manifest
index 130ed992076e..7c5818d96cc2 100644
--- a/dev-libs/pocl/Manifest
+++ b/dev-libs/pocl/Manifest
@@ -1,2 +1,3 @@
DIST pocl-6.0.tar.gz 2466652 BLAKE2B
e074f35bfe8ccd70038fe05ca01da033849bed83075330f1149597455a5892281d4d09b8db5b4731e7e0c248d1ffdc8e8707c1ebe53d50624294ad92aa886be6
SHA512
a24efadbbb81c810cd5c4bbb8abfa75b9bbdfeca786e8471dd75d40a78024d04c1b5c5a7114e75e1eb70a1b6a3756bb47ba741de0f1c4d1416fbce4688d62cc0
DIST pocl-7.0.tar.gz 3766036 BLAKE2B
83bf4417fb0e2b00971c570f2df746cc33ee64df5ae64eea5e50066cef0a33fd45e39ff0e9817ac86dfb775b913623b08367e615296f020832b95cd861791d86
SHA512
cbf0da705eef41d3b1c0710b3d19b2f72ab63acd0a16cea2251ddf796e66b13d38fff97a154f618a38333a121db82e497eb17fa4b45c2a50eb8968786fca7b55
+DIST pocl-7.1.tar.gz 3889905 BLAKE2B
0e89a75df18231697a58d6ac7e20c6c69871578f45ae826cd91f086aa877653a214f9d9f153eeb39e2a0458b73eea3fe8e8ff7e5bee88cbb0dc134597f6f8e97
SHA512
f53c80d9179b350c6fe10550b359f80be03202dd416bf848dd7d200579e29c13339bc1eeafd9f71a8f8b58369ce0644e2227ed84faddbb2254e38ca86a297bbb
diff --git a/dev-libs/pocl/pocl-7.1.ebuild b/dev-libs/pocl/pocl-7.1.ebuild
new file mode 100644
index 000000000000..9d39fedc838b
--- /dev/null
+++ b/dev-libs/pocl/pocl-7.1.ebuild
@@ -0,0 +1,146 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+LLVM_COMPAT=( {18..21} )
+inherit cmake cuda llvm-r1
+
+DESCRIPTION="Portable Computing Language (an implementation of OpenCL)"
+HOMEPAGE="http://portablecl.org https://github.com/pocl/pocl"
+SRC_URI="https://github.com/pocl/pocl/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+
+LICENSE="GPL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~ppc64"
+# TODO: hsa tce
+IUSE="accel +conformance cuda debug examples +hwloc memmanager server spirv
test"
+RESTRICT="!test? ( test )"
+
+CLANG_DEPS="
+ $(llvm_gen_dep '
+ !cuda? (
+ llvm-core/clang:${LLVM_SLOT}=
+ llvm-core/llvm:${LLVM_SLOT}=
+ )
+ cuda? (
+ llvm-core/clang:${LLVM_SLOT}=[llvm_targets_NVPTX]
+ llvm-core/llvm:${LLVM_SLOT}=[llvm_targets_NVPTX]
+ )
+ spirv? (
+ dev-util/spirv-tools
+ dev-util/spirv-llvm-translator:${LLVM_SLOT}=
+ )
+ ')
+"
+RDEPEND="
+ ${CLANG_DEPS}
+ dev-libs/libltdl
+ dev-util/opencl-headers
+ virtual/opencl
+ debug? ( dev-util/lttng-ust:= )
+ cuda? ( dev-util/nvidia-cuda-toolkit:= )
+ hwloc? ( sys-apps/hwloc:=[cuda?] )
+"
+
+DEPEND="${RDEPEND}"
+BDEPEND="
+ ${CLANG_DEPS}
+ virtual/pkgconfig
+"
+
+src_prepare() {
+ use cuda && cuda_src_prepare
+ cmake_src_prepare
+}
+
+src_configure() {
+ local host_cpu_variants="generic"
+
+ if use amd64 ; then
+ # Use pocl's curated list of CPU variants which should contain
a good match for any given amd64 CPU
+ host_cpu_variants="distro"
+ elif use ppc64 ; then
+ # A selection of architectures in which new Altivec / VSX
features were added
+ # This attempts to recreate the amd64 "distro" option for ppc64
+ # See discussion in bug #831859
+ host_cpu_variants="pwr10;pwr9;pwr8;pwr7;pwr6;g5;a2;generic"
+ elif use riscv; then
+ host_cpu_variants="generic-rv64"
+ fi
+
+ local mycmakeargs=(
+ -DENABLE_HSA=OFF
+
+ -DENABLE_ICD=ON
+ -DPOCL_ICD_ABSOLUTE_PATH=ON
+ -DINSTALL_OPENCL_HEADERS=OFF
+
+ # only appends -flto
+ -DENABLE_IPO=OFF
+
+ -DENABLE_POCL_BUILDING=ON
+ -DKERNELLIB_HOST_CPU_VARIANTS="${host_cpu_variants}"
+
+ -DENABLE_LLVM=ON
+ -DSTATIC_LLVM=OFF
+ -DWITH_LLVM_CONFIG=$(get_llvm_prefix -d)/bin/llvm-config
+
+ -DENABLE_ALMAIF_DEVICE=$(usex accel)
+ -DENABLE_CONFORMANCE=$(usex conformance)
+ -DENABLE_CUDA=$(usex cuda)
+ -DENABLE_HWLOC=$(usex hwloc)
+ # Adds sanitizers(!) which aren't suitable for production
+ -DHARDENING_ENABLE=OFF
+ -DPOCL_DEBUG_MESSAGES=$(usex debug)
+ -DUSE_POCL_MEMMANAGER=$(usex memmanager)
+ -DENABLE_EXAMPLES=$(usex examples)
+ -DENABLE_TESTS=$(usex test)
+ -DENABLE_SPIRV=$(usex spirv)
+ -DENABLE_REMOTE_CLIENT=1
+ -DENABLE_REMOTE_SERVER=$(usex server)
+
+ )
+
+ cmake_src_configure
+}
+
+src_test() {
+ local -x POCL_BUILDING=1
+ local -x POCL_DEVICES=basic
+ local -x CTEST_OUTPUT_ON_FAILURE=1
+ local -x TEST_VERBOSE=1
+
+ local CMAKE_SKIP_TESTS=(
+ # These tests hang (or are very slow)
+ regression/infinite_loop_cbs
+ regression/passing_a_constant_array_as_an_arg_loopvec
+ regression/infinite_loop_loopvec
+ regression/passing_a_constant_array_as_an_arg_cbs
+
+ # Failures
+ kernel/test_halfs_loopvec
+ kernel/test_halfs_cbs
+ kernel/test_printf_vectors_halfn_loopvec
+ kernel/test_printf_vectors_halfn_cbs
+ workgroup/conditional_barrier_dynamic
+ workgroup/ballot_loopvec
+ workgroup/ballot_cbs
+ regression/test_rematerialized_alloca_load_with_outside_pr_users
+ )
+
+ #
https://github.com/pocl/pocl/blob/main/.github/workflows/build_linux.yml#L148
+ # There are various CTest labels available, we may want to run just
+ # a subset of those rather than having a large set where we're chasing
+ # random failures from tinderboxing...
+ cmake_src_test
+}
+
+src_install() {
+ cmake_src_install
+
+ if use examples; then
+ dodoc -r examples
+ docompress -x /usr/share/doc/${P}/examples
+ fi
+}