commit:     61a151872957434dc76802939e52cf325f23bc31
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Thu Feb  9 20:20:30 2023 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Thu Feb  9 20:20:35 2023 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=61a15187

dev-libs/rocm-opencl-runtime: restore 5.3.3

Fished out of 154ece10a9374160e04dc82f3dd3a46548cd1c0f.

Bug: https://bugs.gentoo.org/893602
Signed-off-by: Sam James <sam <AT> gentoo.org>

 .../rocm-opencl-runtime-5.3.3.ebuild               | 122 +++++++++++++++++++++
 1 file changed, 122 insertions(+)

diff --git a/dev-libs/rocm-opencl-runtime/rocm-opencl-runtime-5.3.3.ebuild 
b/dev-libs/rocm-opencl-runtime/rocm-opencl-runtime-5.3.3.ebuild
new file mode 100644
index 000000000000..1dc7f3cf3345
--- /dev/null
+++ b/dev-libs/rocm-opencl-runtime/rocm-opencl-runtime-5.3.3.ebuild
@@ -0,0 +1,122 @@
+# Copyright 1999-2023 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit cmake edo flag-o-matic prefix
+
+DESCRIPTION="Radeon Open Compute OpenCL Compatible Runtime"
+HOMEPAGE="https://github.com/RadeonOpenCompute/ROCm-OpenCL-Runtime";
+SRC_URI="https://github.com/ROCm-Developer-Tools/ROCclr/archive/rocm-${PV}.tar.gz
 -> rocclr-${PV}.tar.gz
+       
https://github.com/RadeonOpenCompute/ROCm-OpenCL-Runtime/archive/rocm-${PV}.tar.gz
 -> rocm-opencl-runtime-${PV}.tar.gz"
+
+LICENSE="Apache-2.0 MIT"
+SLOT="0/$(ver_cut 1-2)"
+IUSE="debug test"
+RESTRICT="!test? ( test )"
+KEYWORDS="~amd64"
+
+RDEPEND=">=dev-libs/rocr-runtime-${PV}
+       >=dev-libs/rocm-comgr-${PV}
+       >=dev-libs/rocm-device-libs-${PV}
+       >=virtual/opencl-3
+       media-libs/mesa"
+DEPEND="${RDEPEND}"
+BDEPEND=">=dev-util/rocm-cmake-${PV}
+       media-libs/glew
+       test? ( >=x11-apps/mesa-progs-8.5.0[X] )
+       "
+
+PATCHES=(
+       "${FILESDIR}/${PN}-3.5.0-do-not-install-libopencl.patch"
+)
+
+S="${WORKDIR}/ROCm-OpenCL-Runtime-rocm-${PV}"
+S1="${WORKDIR}/ROCclr-rocm-${PV}"
+
+src_prepare() {
+       # Remove "clinfo" - use "dev-util/clinfo" instead
+       #[ -d tools/clinfo ] && rm -rf tools/clinfo || die
+
+       cmake_src_prepare
+
+       hprefixify amdocl/CMakeLists.txt
+
+       sed -e "s/DESTINATION lib/DESTINATION ${CMAKE_INSTALL_LIBDIR}/g" -i 
packaging/CMakeLists.txt || die
+       # remove trailing CR or it won't work
+       sed -e "s/\r$//g" -i tests/ocltst/module/perf/oclperf.exclude || die
+
+       pushd ${S1} || die
+       # Bug #753377
+       # patch re-enables accidentally disabled gfx800 family
+       eapply "${FILESDIR}/${PN}-5.0.2-enable-gfx800.patch"
+       popd || die
+}
+
+src_configure() {
+       # Reported upstream: 
https://github.com/RadeonOpenCompute/ROCm-OpenCL-Runtime/issues/120
+       append-cflags -fcommon
+
+       local mycmakeargs=(
+               -Wno-dev
+               -DROCCLR_PATH="${S1}"
+               -DAMD_OPENCL_PATH="${S}"
+               -DROCM_PATH="${EPREFIX}/usr"
+               -DBUILD_TESTS=$(usex test ON OFF)
+               -DEMU_ENV=ON
+               # -DCMAKE_STRIP=""
+       )
+       cmake_src_configure
+}
+
+src_install() {
+       insinto /etc/OpenCL/vendors
+       doins config/amdocl64.icd
+
+       cd "${BUILD_DIR}" || die
+       insinto /usr/lib64
+       doins amdocl/libamdocl64.so
+       doins tools/cltrace/libcltrace.so
+}
+
+# Copied from rocm.eclass. This ebuild does not need amdgpu_targets
+# USE_EXPANDS, so it should not inherit rocm.eclass; it only uses the
+# check_amdgpu function in src_test. Rename it to check-amdgpu to avoid
+# pkgcheck warning.
+check-amdgpu() {
+       for device in /dev/kfd /dev/dri/render*; do
+               addwrite ${device}
+               if [[ ! -r ${device} || ! -w ${device} ]]; then
+                       eerror "Cannot read or write ${device}!"
+                       eerror "Make sure it is present and check the 
permission."
+                       ewarn "By default render group have access to it. Check 
if portage user is in render group."
+                       die "${device} inaccessible"
+               fi
+       done
+}
+
+src_test() {
+       check-amdgpu
+       cd "${BUILD_DIR}"/tests/ocltst || die
+       export OCL_ICD_FILENAMES="${BUILD_DIR}"/amdocl/libamdocl64.so
+       local instruction1="Please start an X server using amdgpu driver (not 
Xvfb!),"
+       local instruction2="and export OCLGL_DISPLAY=\${DISPLAY} 
OCLGL_XAUTHORITY=\${XAUTHORITY} before reruning the test."
+       if [[ -n ${OCLGL_DISPLAY+x} ]]; then
+               export DISPLAY=${OCLGL_DISPLAY}
+               export XAUTHORITY=${OCLGL_XAUTHORITY}
+               ebegin "Running oclgl test under DISPLAY ${OCLGL_DISPLAY}"
+               if ! glxinfo | grep "OpenGL vendor string: AMD"; then
+                       ewarn "${instruction1}"
+                       ewarn "${instruction2}"
+                       die "This display does not have AMD OpenGL vendor!"
+               fi
+               ./ocltst -m liboclgl.so -A ogl.exclude
+               eend $? || die "oclgl test failed"
+       else
+               ewarn "${instruction1}"
+               ewarn "${instruction2}"
+               die "\${OCLGL_DISPLAY} not set."
+       fi
+       edob ./ocltst -m liboclruntime.so -A oclruntime.exclude
+       edob ./ocltst -m liboclperf.so -A oclperf.exclude
+}

Reply via email to