summaryrefslogtreecommitdiff
path: root/media-libs/osl
diff options
context:
space:
mode:
Diffstat (limited to 'media-libs/osl')
-rw-r--r--media-libs/osl/Manifest6
-rw-r--r--media-libs/osl/metadata.xml5
-rw-r--r--media-libs/osl/osl-1.12.14.0-r1.ebuild384
-rw-r--r--media-libs/osl/osl-1.13.7.0.ebuild453
-rw-r--r--media-libs/osl/osl-9999.ebuild443
5 files changed, 1289 insertions, 2 deletions
diff --git a/media-libs/osl/Manifest b/media-libs/osl/Manifest
index 6da4bf37bbda..f14d1bcc7942 100644
--- a/media-libs/osl/Manifest
+++ b/media-libs/osl/Manifest
@@ -2,8 +2,12 @@ DIST osl-1.12.11.0.tar.gz 20287156 BLAKE2B 178db816980929cc61a0deea63f715a9f10ad
DIST osl-1.12.13.0.tar.gz 20286745 BLAKE2B 75a2a5d10000ba26cd11463dde710d5be3b8b2d227de45263d8bd39fd87ca064f7c6d2b2f9cea2fdb8f29ccaa94d3ef60e2ff2e0e6d867385e2298dd10ef61b6 SHA512 d7e6ab79f77f2854cbb4fa2fbe5fc92659bb015b1bbffcee2ef86185cf20235990fa3b20308601aa298fedc85d3fcd4451b7b7ff0df7def97027efe4fb8a02bc
DIST osl-1.12.14.0.tar.gz 20555853 BLAKE2B 4f6bc2084e4c1b25e707a37830961f20926e6ab5cb915c763cbd8126127e70f6368832077729ab5e044f573e8c38c4afb413eff8adccee5ea1ae96cb9be43b6e SHA512 51641e58fb0bba042853e3976c104decc788f1b1d3ec2e33a3f5504b11b05950dc38766ffb066b0f76edc4e0a8829d6b7dd408d9288b74d69380395b1d991bd5
DIST osl-1.12.7.0.tar.gz 20250356 BLAKE2B a9398243546b1bfc1e3f9602f6112a72a8e7cb6ace54e93d0e5f30d943474e82c3317596597d6a09e0f2cf04b1b21f05c31a2357e3d667d710cd2aa340f5fd63 SHA512 ec0391dfc95140fee4fa8332991cdcb0978dafc436f3e07d0293e2baa2014b8765e6b60631ae5a8bbd6e16dbcf37f04c076d7d6b2d8bfa58b78471f0d92c433f
+DIST osl-1.13.7.0.tar.gz 21774349 BLAKE2B 1fd731f14b8dce948d7995efadb63eec8ce028ed6b095db391d2dfedcbbd62ca3aad9cd5d7d40f94c9e358f952d841899103467a2f81b12a605ae8c8436a16ff SHA512 15ffc6a5eed44141672af3d7ddab5d97abacad2062cddb35ef2a8484538a9a9a86cbd7e7170deafcefd3b69df764bfd207685603ca17a2fbff4299ccd1afe569
EBUILD osl-1.12.11.0.ebuild 2654 BLAKE2B 03dbc702cf4ee912aaa9c8e6fc367c1d329e4197c921b83530ef067655bc5d9707709ff1faabccec73afc5cdca1c35e13b332f27c1753e995d15e175be27faa2 SHA512 eb64532b37668c315ece45468dff7de849a80cd4a4d977e9ec3fe248d844deb431eeefeb54e6cfdc886cdae8db25573cd6345e7df0ab09c8dd8a0844f5bc17bc
EBUILD osl-1.12.13.0.ebuild 2937 BLAKE2B d0cc000f15b02c06109d3bfeec16423da744b8b3aa4eae200cc2e34edc92d5aa9dc63652e6291e4deb37e96dc0c2815a936e920cbb560c72936543e63b977876 SHA512 d0293f173cbaff89eef8c7d00bf4a1c23b10af4cfe4091d9cf0dbda9a4321ebc8f8954e1fca40c59ca2f539583dfced2ac61f634a9d3a5579fdffde97a3defc9
+EBUILD osl-1.12.14.0-r1.ebuild 9613 BLAKE2B 04555418eaefc10e9e308f8ea1a53086953539e57eb2e17c4d1b5fd7e57a7a21c4f00ec8879c902ce65daf8ea5c30538791561830779660e9edfb6f3aaea4977 SHA512 e97f7b6f5e70be2c78d99ebc38c320c60722dbfb7534814ce60cba6fa6e4722683edbbbb8dfce403fe02ef89038ea645bb6de3b606dd7e9e1d6fb025d83ddfb9
EBUILD osl-1.12.14.0.ebuild 3696 BLAKE2B 73bf112684b06c5c75521a8df1e7963551a21caabb53754cc8455d949417079bca07afbf092f7c173490a5ed0003aa163a2731ce8a5b7be4bf4fbfaf36688024 SHA512 fe1b2b7bb061eeba5dbee874e9fa4a429430c8b9aadc473aaa6736ac824bd84389a0365154ad06e4ebb92ede7198c6611310772bc787b2c553683eb542f52a3c
EBUILD osl-1.12.7.0.ebuild 2761 BLAKE2B b70f2c5c5d7a8cd3d5031f35562e3266d21e5212a53ca5ea2ea4c8d2476651095e6140c6490648ab0fcc2c629e81d4ec628155bbea8d78899446e906596d065d SHA512 daede9ce4d5d366bcba462adfad893fe19d9d41b05adc807632b9d67422b452170a2cb453fefba826877f4bbafc4639311aab457f16ffc324b66f8688c0e517c
-MISC metadata.xml 930 BLAKE2B 2108a2c31a921fbf2cbeeeb2b06349b8a0f7d0229cdef29d6f48b3f12979f40eab9e2b735a2c4717b69b0661390b400414c20f77da3003ae3ba806d49e614d6f SHA512 b4aed7a6508c6e52a457c415a230658f2dbc33586f32fa4baa84217cf2603c8ebb9cd227ce317c75237d306284f2b066564941796e5ada0bfbc615337b84955a
+EBUILD osl-1.13.7.0.ebuild 11533 BLAKE2B 9320d920aff47d4395b269eb6be65dfe701167e17ea2a47cfd4de8ba04a89c403a83a0c5933d719c0a4dc6c4f304cad70f2fce4a6c6c8d26cf81025d99ec4217 SHA512 7d5a69ced126993510c6456e4e2fad3c47c41280093900faaabc7589f1f5cd3f714ae73e794c9a3a7ee2da0d4b8bf954a132706a2f43d1577f04a4eab4662165
+EBUILD osl-9999.ebuild 11256 BLAKE2B e40121253e1952e48d71027849c1b24c0053a2c4b7082ef01c07ac32cd3c1a242528a2affc3e665d68eb228725a231bddea4f1d333313cf6429a78c55deb1508 SHA512 d3aecb569f1a24f9e9c13c37b5829dbd422705e0df35404721687d32ee3675de0a37501d2641913ad79cfd31851b9506bea4047af71b66c39ab081c34a930659
+MISC metadata.xml 1162 BLAKE2B 56fc654915ef7d354844d8b9d99cbe1e2fa8ece1bf3ee2028847d8add16c663cab3110598ae78b7da05c6f3b06bc0926ff1797827c5b2750c03ec02d4c5effe2 SHA512 6e391782385aca530fb9526dd4675845aefd42d760555a7633b0daec2d2890e5d2ce93f39b4c297c1f1056e2c4607c228baba4a1875f05c47362abeb50455dba
diff --git a/media-libs/osl/metadata.xml b/media-libs/osl/metadata.xml
index 4e777e0e9393..4c2f57c8a0ed 100644
--- a/media-libs/osl/metadata.xml
+++ b/media-libs/osl/metadata.xml
@@ -15,8 +15,11 @@
lights, displacement, and pattern generation.
</longdescription>
<use>
- <flag name="partio">Use <pkg>media-libs/partio</pkg></flag>
<flag name="gui">Build the osltoy binary (with Qt5)</flag>
+ <flag name="libcxx">Build against <pkg>sys-libs/libcxx</pkg> when using clang</flag>
+ <flag name="nofma">Do not use Fuse-Multiply-Add operations</flag>
+ <flag name="optix">Add support for NVIDIA's OptiX Raytracing Engine</flag>
+ <flag name="partio">Use <pkg>media-libs/partio</pkg></flag>
<flag name="qt6">Build the osltoy binary (with Qt6)</flag>
</use>
<upstream>
diff --git a/media-libs/osl/osl-1.12.14.0-r1.ebuild b/media-libs/osl/osl-1.12.14.0-r1.ebuild
new file mode 100644
index 000000000000..66765c891954
--- /dev/null
+++ b/media-libs/osl/osl-1.12.14.0-r1.ebuild
@@ -0,0 +1,384 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+
+# Check this on updates
+LLVM_COMPAT=( {15..15} )
+
+inherit cmake flag-o-matic llvm-r1 toolchain-funcs python-single-r1
+
+DESCRIPTION="Advanced shading language for production GI renderers"
+HOMEPAGE="https://www.imageworks.com/technology/opensource https://github.com/AcademySoftwareFoundation/OpenShadingLanguage"
+
+if [[ ${PV} = *9999* ]] ; then
+ inherit git-r3
+ EGIT_REPO_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage.git"
+else
+ # If a development release, please don't keyword!
+ SRC_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+ KEYWORDS="~amd64 ~arm ~arm64 ~ppc64"
+fi
+
+S="${WORKDIR}/OpenShadingLanguage-${PV}"
+
+LICENSE="BSD"
+SLOT="0/$(ver_cut 1-3)"
+
+X86_CPU_FEATURES=(
+ sse2:sse2 sse3:sse3 ssse3:ssse3 sse4_1:sse4.1 sse4_2:sse4.2
+ avx:avx avx2:avx2 avx512f:avx512f f16c:f16c
+)
+CPU_FEATURES=( "${X86_CPU_FEATURES[@]/#/cpu_flags_x86_}" )
+
+IUSE="doc gui libcxx nofma partio qt6 test ${CPU_FEATURES[*]%:*} python"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+RDEPEND="
+ dev-libs/boost:=
+ dev-libs/pugixml
+ >=media-libs/openexr-3:0=
+ >=media-libs/openimageio-2.4:=
+ $(llvm_gen_dep '
+ sys-devel/clang:${LLVM_SLOT}
+ sys-devel/llvm:${LLVM_SLOT}
+ ')
+ sys-libs/zlib:=
+ python? (
+ ${PYTHON_DEPS}
+ $(python_gen_cond_dep '
+ dev-python/pybind11[${PYTHON_USEDEP}]
+ media-libs/openimageio[python,${PYTHON_SINGLE_USEDEP}]
+ ')
+ )
+ partio? ( media-libs/partio )
+ gui? (
+ !qt6? (
+ dev-qt/qtcore:5
+ dev-qt/qtgui:5
+ dev-qt/qtwidgets:5
+ dev-qt/qtopengl:5
+ )
+ qt6? (
+ dev-qt/qtbase:6[gui,widgets,opengl]
+ )
+ )
+"
+
+DEPEND="${RDEPEND}"
+BDEPEND="
+ sys-devel/bison
+ sys-devel/flex
+ virtual/pkgconfig
+"
+
+pkg_setup() {
+ llvm-r1_pkg_setup
+
+ use python && python-single-r1_pkg_setup
+}
+
+src_prepare() {
+ sed -e "/^install.*llvm_macros.cmake.*cmake/d" -i CMakeLists.txt || die
+
+ cmake_src_prepare
+}
+
+src_configure() {
+ # pick the highest we support
+ local mysimd=()
+ if use cpu_flags_x86_avx512f; then
+ mysimd+=( avx512f )
+ elif use cpu_flags_x86_avx2 ; then
+ mysimd+=( avx2 )
+ if use cpu_flags_x86_f16c ; then
+ mysimd+=( f16c )
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mysimd+=( avx )
+ elif use cpu_flags_x86_sse4_2 ; then
+ mysimd+=( sse4.2 )
+ elif use cpu_flags_x86_sse4_1 ; then
+ mysimd+=( sse4.1 )
+ elif use cpu_flags_x86_ssse3 ; then
+ mysimd+=( ssse3 )
+ elif use cpu_flags_x86_sse3 ; then
+ mysimd+=( sse3 )
+ elif use cpu_flags_x86_sse2 ; then
+ mysimd+=( sse2 )
+ fi
+
+ local mybatched=()
+ if use cpu_flags_x86_avx512f || use cpu_flags_x86_avx2 ; then
+ if use cpu_flags_x86_avx512f ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX512_noFMA"
+ "b16_AVX512_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX512"
+ "b16_AVX512"
+ )
+ fi
+ fi
+ if use cpu_flags_x86_avx2 ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX2_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX2"
+ )
+ fi
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mybatched+=(
+ "b8_AVX"
+ )
+ fi
+
+ # If no CPU SIMDs were used, completely disable them
+ [[ -z "${mysimd[*]}" ]] && mysimd=("0")
+ [[ -z "${mybatched[*]}" ]] && mybatched=("0")
+
+ # This is currently needed on arm64 to get the NEON SIMD wrapper to compile the code successfully
+ # Even if there are no SIMD features selected, it seems like the code will turn on NEON support if it is available.
+ use arm64 && append-flags -flax-vector-conversions
+
+ local gcc
+ gcc="$(tc-getCC)"
+
+ local mycmakeargs=(
+ -DCMAKE_POLICY_DEFAULT_CMP0146="OLD" # BUG FindCUDA
+ -DCMAKE_POLICY_DEFAULT_CMP0148="OLD" # BUG FindPythonInterp
+
+ # std::tuple_size_v is c++17
+ -DCMAKE_CXX_STANDARD="17"
+
+ -DCMAKE_INSTALL_DOCDIR="share/doc/${PF}"
+ -DINSTALL_DOCS="$(usex doc)"
+ -DUSE_CCACHE="no"
+ -DLLVM_STATIC="no"
+ -DOSL_BUILD_TESTS="$(usex test)"
+ -DSTOP_ON_WARNING="no"
+ -DUSE_PARTIO="$(usex partio)"
+ -DUSE_PYTHON="$(usex python)"
+ -DPYTHON_VERSION="${EPYTHON/python}"
+ -DUSE_SIMD="$(IFS=","; echo "${mysimd[*]}")"
+ -DUSE_BATCHED="$(IFS=","; echo "${mybatched[*]}")"
+ -DUSE_LIBCPLUSPLUS="$(usex libcxx)"
+ -DUSE_OPTIX="no"
+ -DVEC_REPORT="yes"
+
+ -DOpenImageIO_ROOT="${EPREFIX}/usr"
+ )
+
+ if use gui; then
+ mycmakeargs+=( -DUSE_QT="yes" )
+ if ! use qt6; then
+ mycmakeargs+=( -DCMAKE_DISABLE_FIND_PACKAGE_Qt6="yes" )
+ fi
+ else
+ mycmakeargs+=( -DUSE_QT="no" )
+ fi
+
+ if use partio; then
+ mycmakeargs+=(
+ -Dpartio_ROOT="${EPREFIX}/usr"
+ )
+ fi
+
+ cmake_src_configure
+}
+
+src_test() {
+ # A bunch of tests only work when installed.
+ # So install them into the temp directory now.
+ DESTDIR="${T}" cmake_build install
+
+ ln -s "${CMAKE_USE_DIR}/src/cmake/" "${BUILD_DIR}/src/cmake" || die
+
+ CMAKE_SKIP_TESTS=(
+ "broken"
+ "^render"
+
+ # outright fail
+ "^color$"
+ "^color.opt$"
+ "^color.batched$"
+ "^color.batched.opt$"
+ "^matrix.batched.opt$"
+ "^spline-reg.regress.batched.opt$"
+ "^transform-reg.regress.batched.opt$"
+ )
+
+ # These only fail inside sandbox
+ if [[ "${OSL_OPTIONAL_TESTS}" != "true" ]]; then
+ CMAKE_SKIP_TESTS+=(
+ # TODO: investigate failures
+ # SIGABRT similar to https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/issues/1363
+ "^andor-reg.regress.batched.opt$"
+ "^arithmetic-reg.regress.batched.opt$"
+ "^array-assign-reg.regress.batched.opt$"
+ "^array-length-reg.regress.batched$"
+ "^closure.batched$"
+ "^closure.batched.opt$"
+ "^closure-parameters.batched$"
+ "^closure-parameters.batched.opt$"
+ "^debug-uninit$"
+ "^debug-uninit.opt$"
+ "^debug-uninit.batched$"
+ "^debug-uninit.batched.opt$"
+ "^derivs$"
+ "^derivs.opt$"
+ "^derivs.batched$"
+ "^derivs.batched.opt$"
+ "^filterwidth-reg.regress.batched.opt$"
+ "^geomath.opt$"
+ "^geomath.batched$"
+ "^geomath.batched.opt$"
+ "^getattribute-camera.batched$"
+ "^getattribute-camera.batched.opt$"
+ "^getattribute-shader.batched.opt$"
+ "^gettextureinfo.batched$"
+ "^gettextureinfo-reg.regress.batched.opt$"
+ "^hyperb.opt$"
+ "^hyperb.batched.opt$"
+ "^ieee_fp-reg.regress.batched.opt$"
+ "^initlist.batched$"
+ "^initlist.batched.opt$"
+ "^isconnected.batched$"
+ "^linearstep.batched$"
+ "^linearstep.batched.opt$"
+ "^loop.batched$"
+ "^loop.batched.opt$"
+ "^matrix$"
+ "^matrix.opt$"
+ "^matrix.batched$"
+ "^matrix-compref-reg.regress.batched.opt$"
+ "^message-no-closure.batched$"
+ "^message-no-closure.batched.opt$"
+ "^message-reg.regress.batched.opt$"
+ "^miscmath$"
+ "^miscmath.opt$"
+ "^miscmath.batched$"
+ "^miscmath.batched.opt$"
+ "^noise.batched$"
+ "^noise-cell.batched$"
+ "^noise-gabor.batched$"
+ "^noise-gabor.batched.opt$"
+ "^noise-gabor-reg.regress.batched.opt$"
+ "^noise-generic.batched$"
+ "^noise-generic.batched.opt$"
+ "^noise-perlin.batched$"
+ "^noise-perlin.batched.opt$"
+ "^noise-simplex.batched$"
+ "^noise-simplex.batched.opt$"
+ "^noise-reg.regress.batched.opt$"
+ "^pnoise.batched$"
+ "^pnoise-cell.batched$"
+ "^pnoise-gabor.batched$"
+ "^pnoise-gabor.batched.opt$"
+ "^pnoise-generic.batched$"
+ "^pnoise-generic.batched.opt$"
+ "^pnoise-perlin.batched$"
+ "^pnoise-perlin.batched.opt$"
+ "^pnoise-reg.regress.batched.opt$"
+ "^opt-warnings.batched$"
+ "^opt-warnings.batched.opt$"
+ "^regex-reg.regress.batched.opt$"
+ "^select.batched$"
+ "^select.batched.opt$"
+ "^shaderglobals.batched$"
+ "^shaderglobals.batched.opt$"
+ "^smoothstep-reg.regress.batched.opt$"
+ "^spline.batched$"
+ "^spline.batched.opt$"
+ "^splineinverse-ident.batched$"
+ "^splineinverse-ident.batched.opt$"
+ "^spline-derivbug.batched$"
+ "^spline-derivbug.batched.opt$"
+ "^split-reg.regress.batched.opt$"
+ "^string.batched$"
+ "^string.batched.opt$"
+ "^string-reg.regress.batched.opt$"
+ "^struct.batched$"
+ "^struct-array-mixture.batched$"
+ "^struct-array-mixture.batched.opt$"
+ "^texture-environment-opts-reg.regress.batched.opt$"
+ "^texture-opts-reg.regress.batched.opt$"
+ "^texture-wrap.batched$"
+ "^texture-wrap.batched.opt$"
+ "^transcendental-reg.regress.batched.opt$"
+ "^transform$"
+ "^transform.opt$"
+ "^transform.batched$"
+ "^transform.batched.opt$"
+ "^transformc$"
+ "^transformc.opt$"
+ "^transformc.batched$"
+ "^transformc.batched.opt$"
+ "^trig$"
+ "^trig.opt$"
+ "^trig.batched$"
+ "^trig.batched.opt$"
+ "^trig-reg.regress.batched.opt$"
+ "^vecctr.batched$"
+ "^vecctr.batched.opt$"
+ "^vector-reg.regress.batched.opt$"
+ "^xml-reg.regress.batched.opt$"
+ "^gettextureinfo-udim.batched$"
+ "^gettextureinfo-udim.batched.opt$"
+ "^gettextureinfo-udim-reg.regress.batched.opt$"
+ "^pointcloud.batched$"
+ "^pointcloud.batched.opt$"
+ )
+ fi
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ )
+
+ local -x DEBUG CXXFLAGS LD_LIBRARY_PATH DIR OSL_DIR OSL_SOURCE_DIR PYTHONPATH
+ DEBUG=1 # doubles the floating point tolerance
+ CXXFLAGS="-I${T}/usr/include"
+ LD_LIBRARY_PATH="${T}/usr/$(get_libdir)"
+ OSL_DIR="${T}/usr/$(get_libdir)/cmake/OSL"
+ OSL_SOURCE_DIR="${S}"
+
+ if use python; then
+ PYTHONPATH="${BUILD_DIR}/lib/python/site-packages"
+ fi
+
+ cmake_src_test
+
+ CMAKE_SKIP_TESTS=(
+ "^render-background$"
+ "^render-bumptest$"
+ "^render-mx-furnace-sheen$"
+ "^render-mx-burley-diffuse$"
+ "^render-mx-conductor$"
+ "^render-mx-generalized-schlick-glass$"
+ "^render-microfacet$"
+ "^render-oren-nayar$"
+ "^render-veachmis$"
+ "^render-ward$"
+ "^render-raytypes.opt$"
+ )
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ --repeat until-pass:10
+ -R "^render"
+ )
+
+ cmake_src_test
+}
diff --git a/media-libs/osl/osl-1.13.7.0.ebuild b/media-libs/osl/osl-1.13.7.0.ebuild
new file mode 100644
index 000000000000..673742be896a
--- /dev/null
+++ b/media-libs/osl/osl-1.13.7.0.ebuild
@@ -0,0 +1,453 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+
+# Check this on updates
+LLVM_COMPAT=( {15..17} )
+
+inherit cmake cuda flag-o-matic llvm-r1 toolchain-funcs python-single-r1
+
+DESCRIPTION="Advanced shading language for production GI renderers"
+HOMEPAGE="https://www.imageworks.com/technology/opensource https://github.com/AcademySoftwareFoundation/OpenShadingLanguage"
+
+if [[ ${PV} = *9999* ]] ; then
+ inherit git-r3
+ EGIT_REPO_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage.git"
+else
+ # If a development release, please don't keyword!
+ SRC_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+ KEYWORDS="~amd64 ~arm ~arm64 ~ppc64"
+fi
+
+S="${WORKDIR}/OpenShadingLanguage-${PV}"
+
+LICENSE="BSD"
+SLOT="0/$(ver_cut 1-3)"
+
+X86_CPU_FEATURES=(
+ sse2:sse2 sse3:sse3 ssse3:ssse3 sse4_1:sse4.1 sse4_2:sse4.2
+ avx:avx avx2:avx2 avx512f:avx512f f16c:f16c
+)
+CPU_FEATURES=( "${X86_CPU_FEATURES[@]/#/cpu_flags_x86_}" )
+
+IUSE="doc gui libcxx nofma optix partio qt6 test ${CPU_FEATURES[*]%:*} python"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+# TODO optix
+RDEPEND="
+ dev-libs/boost:=
+ dev-libs/pugixml
+ >=media-libs/openexr-3:0=
+ >=media-libs/openimageio-2.4:=
+ $(llvm_gen_dep '
+ sys-devel/clang:${LLVM_SLOT}
+ sys-devel/llvm:${LLVM_SLOT}
+ ')
+ sys-libs/zlib:=
+ optix? ( dev-libs/optix[-headers-only] )
+ python? (
+ ${PYTHON_DEPS}
+ $(python_gen_cond_dep '
+ dev-python/pybind11[${PYTHON_USEDEP}]
+ media-libs/openimageio[python,${PYTHON_SINGLE_USEDEP}]
+ ')
+ )
+ partio? ( media-libs/partio )
+ gui? (
+ !qt6? (
+ dev-qt/qtcore:5
+ dev-qt/qtgui:5
+ dev-qt/qtwidgets:5
+ dev-qt/qtopengl:5
+ )
+ qt6? (
+ dev-qt/qtbase:6[gui,widgets,opengl]
+ )
+ )
+"
+
+DEPEND="${RDEPEND}"
+BDEPEND="
+ sys-devel/bison
+ sys-devel/flex
+ virtual/pkgconfig
+"
+
+pkg_setup() {
+ llvm-r1_pkg_setup
+
+ use python && python-single-r1_pkg_setup
+}
+
+src_prepare() {
+ if use optix; then
+ cuda_src_prepare
+ cuda_add_sandbox -w
+ fi
+
+ sed -e "/^install.*llvm_macros.cmake.*cmake/d" -i CMakeLists.txt || die
+
+ cmake_src_prepare
+}
+
+src_configure() {
+ # pick the highest we support
+ local mysimd=()
+ if use cpu_flags_x86_avx512f; then
+ mysimd+=( avx512f )
+ elif use cpu_flags_x86_avx2 ; then
+ mysimd+=( avx2 )
+ if use cpu_flags_x86_f16c ; then
+ mysimd+=( f16c )
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mysimd+=( avx )
+ elif use cpu_flags_x86_sse4_2 ; then
+ mysimd+=( sse4.2 )
+ elif use cpu_flags_x86_sse4_1 ; then
+ mysimd+=( sse4.1 )
+ elif use cpu_flags_x86_ssse3 ; then
+ mysimd+=( ssse3 )
+ elif use cpu_flags_x86_sse3 ; then
+ mysimd+=( sse3 )
+ elif use cpu_flags_x86_sse2 ; then
+ mysimd+=( sse2 )
+ fi
+
+ local mybatched=()
+ if use cpu_flags_x86_avx512f || use cpu_flags_x86_avx2 ; then
+ if use cpu_flags_x86_avx512f ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX512_noFMA"
+ "b16_AVX512_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX512"
+ "b16_AVX512"
+ )
+ fi
+ fi
+ if use cpu_flags_x86_avx2 ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX2_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX2"
+ )
+ fi
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mybatched+=(
+ "b8_AVX"
+ )
+ fi
+
+ # If no CPU SIMDs were used, completely disable them
+ [[ -z "${mysimd[*]}" ]] && mysimd=("0")
+ [[ -z "${mybatched[*]}" ]] && mybatched=("0")
+
+ # This is currently needed on arm64 to get the NEON SIMD wrapper to compile the code successfully
+ # Even if there are no SIMD features selected, it seems like the code will turn on NEON support if it is available.
+ use arm64 && append-flags -flax-vector-conversions
+
+ local gcc
+ gcc="$(tc-getCC)"
+
+ local mycmakeargs=(
+ -DCMAKE_POLICY_DEFAULT_CMP0146="OLD" # BUG FindCUDA
+ -DCMAKE_POLICY_DEFAULT_CMP0148="OLD" # BUG FindPythonInterp
+
+ # std::tuple_size_v is c++17
+ -DCMAKE_CXX_STANDARD="17"
+
+ -DCMAKE_INSTALL_DOCDIR="share/doc/${PF}"
+ -DINSTALL_DOCS="$(usex doc)"
+ -DUSE_CCACHE="no"
+ -DLLVM_STATIC="no"
+ -DOSL_BUILD_TESTS="$(usex test)"
+ -DSTOP_ON_WARNING="no"
+ -DUSE_PARTIO="$(usex partio)"
+ -DUSE_PYTHON="$(usex python)"
+ -DPYTHON_VERSION="${EPYTHON/python}"
+ -DUSE_SIMD="$(IFS=","; echo "${mysimd[*]}")"
+ -DUSE_BATCHED="$(IFS=","; echo "${mybatched[*]}")"
+ -DUSE_LIBCPLUSPLUS="$(usex libcxx)"
+ -DOSL_USE_OPTIX="$(usex optix)"
+ -DVEC_REPORT="yes"
+
+ -DOpenImageIO_ROOT="${EPREFIX}/usr"
+ )
+
+ if use gui; then
+ mycmakeargs+=( -DUSE_QT="yes" )
+ if ! use qt6; then
+ mycmakeargs+=( -DCMAKE_DISABLE_FIND_PACKAGE_Qt6="yes" )
+ fi
+ else
+ mycmakeargs+=( -DUSE_QT="no" )
+ fi
+
+ if use optix; then
+ mycmakeargs+=(
+ -DOptiX_FIND_QUIETLY="no"
+ -DCUDA_FIND_QUIETLY="no"
+
+ -DOPTIXHOME="${EPREFIX}/opt/optix"
+ -DCUDA_TOOLKIT_ROOT_DIR="${EPREFIX}/opt/cuda"
+
+ -DCUDA_NVCC_FLAGS="--compiler-bindir;$(cuda_gccdir)"
+ -DOSL_EXTRA_NVCC_ARGS="--compiler-bindir;$(cuda_gccdir)"
+ -DCUDA_VERBOSE_BUILD="yes"
+ )
+ fi
+
+ if use partio; then
+ mycmakeargs+=(
+ -Dpartio_DIR="${EPREFIX}/usr"
+ )
+ fi
+
+ cmake_src_configure
+}
+
+src_test() {
+ # A bunch of tests only work when installed.
+ # So install them into the temp directory now.
+ DESTDIR="${T}" cmake_build install
+
+ ln -s "${CMAKE_USE_DIR}/src/cmake/" "${BUILD_DIR}/src/cmake" || die
+
+ if use optix; then
+ cp \
+ "${BUILD_DIR}/src/liboslexec/shadeops_cuda.ptx" \
+ "${BUILD_DIR}/src/testrender/"{optix_raytracer,quad,rend_lib_testrender,sphere,wrapper}".ptx" \
+ "${BUILD_DIR}/src/testshade/"{optix_grid_renderer,rend_lib_testshade}".ptx" \
+ "${BUILD_DIR}/bin/" || die
+
+ # NOTE this should go to cuda eclass
+ addwrite /dev/nvidiactl
+ addwrite /dev/nvidia0
+ addwrite /dev/nvidia-uvm
+ addwrite /dev/nvidia-caps
+ addwrite "/dev/char/"
+ fi
+
+ CMAKE_SKIP_TESTS=(
+ "broken"
+ "^render"
+
+ # broken with in-tree <=dev-libs/optix-7.5.0 and out of date
+ "^example-cuda$"
+
+ # outright fail
+ "^transform-reg.regress.batched.opt$"
+
+ # SIGABRT similar to https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/issues/1363
+ "^derivs.opt.rs_bitcode$"
+ "^geomath.batched$"
+ "^matrix.batched$"
+ "^matrix.batched.opt$"
+ "^spline-reg.regress.batched.opt$"
+ "^transformc.batched$"
+ )
+
+ # These only fail inside sandbox
+ if [[ "${OSL_OPTIONAL_TESTS}" != "true" ]]; then
+ CMAKE_SKIP_TESTS+=(
+ # TODO: investigate failures
+ # SIGABRT similar to https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/issues/1363
+ "^andor-reg.regress.batched.opt$"
+ "^arithmetic-reg.regress.batched.opt$"
+ "^array-assign-reg.regress.batched.opt$"
+ "^array-copy-reg.regress.batched.opt$"
+ "^array-length-reg.regress.batched$"
+ "^bug-outputinit.optix$"
+ "^bug-outputinit.optix.fused$"
+ "^bug-outputinit.optix.opt$"
+ "^bug-return.optix$"
+ "^bug-return.optix.fused$"
+ "^bug-return.optix.opt$"
+ "^closure-parameters.batched$"
+ "^closure-parameters.batched.opt$"
+ "^closure.batched$"
+ "^closure.batched.opt$"
+ "^debug-uninit$"
+ "^debug-uninit.batched$"
+ "^debug-uninit.batched.opt$"
+ "^debug-uninit.opt$"
+ "^debug-uninit.opt.rs_bitcode$"
+ "^derivs$"
+ "^derivs.batched$"
+ "^derivs.batched.opt$"
+ "^derivs.opt$"
+ "^exponential$"
+ "^exponential.opt$"
+ "^exponential.opt.rs_bitcode$"
+ "^filterwidth-reg.regress.batched.opt$"
+ "^geomath$"
+ "^geomath.batched.opt$"
+ "^geomath.opt$"
+ "^geomath.opt.rs_bitcode$"
+ "^getattribute-camera.batched$"
+ "^getattribute-camera.batched.opt$"
+ "^getattribute-shader.batched.opt$"
+ "^gettextureinfo-reg.regress.batched.opt$"
+ "^gettextureinfo-udim-reg.regress.batched.opt$"
+ "^gettextureinfo.batched$"
+ "^hyperb.batched.opt$"
+ "^hyperb.opt$"
+ "^hyperb.opt.rs_bitcode$"
+ "^initlist.batched$"
+ "^initlist.batched.opt$"
+ "^linearstep.batched$"
+ "^linearstep.batched.opt$"
+ "^loop.batched$"
+ "^loop.batched.opt$"
+ "^matrix$"
+ "^matrix-compref-reg.regress.batched.opt$"
+ "^matrix-reg.regress.rsbitcode.opt$"
+ "^matrix.opt$"
+ "^matrix.opt.rs_bitcode$"
+ "^matrix.rsbitcode.opt$"
+ "^message-no-closure.batched$"
+ "^message-no-closure.batched.opt$"
+ "^message-reg.regress.batched.opt$"
+ "^miscmath$"
+ "^miscmath.batched$"
+ "^miscmath.batched.opt$"
+ "^miscmath.opt$"
+ "^miscmath.opt.rs_bitcode$"
+ "^noise-cell.batched$"
+ "^noise-gabor-reg.regress.batched.opt$"
+ "^noise-gabor.batched$"
+ "^noise-gabor.batched.opt$"
+ "^noise-generic.batched$"
+ "^noise-generic.batched.opt$"
+ "^noise-perlin.batched$"
+ "^noise-perlin.batched.opt$"
+ "^noise-reg.regress.batched.opt$"
+ "^noise-simplex.batched$"
+ "^noise-simplex.batched.opt$"
+ "^noise.batched$"
+ "^opt-warnings.batched$"
+ "^opt-warnings.batched.opt$"
+ "^pnoise-cell.batched$"
+ "^pnoise-gabor.batched$"
+ "^pnoise-gabor.batched.opt$"
+ "^pnoise-generic.batched$"
+ "^pnoise-generic.batched.opt$"
+ "^pnoise-perlin.batched$"
+ "^pnoise-perlin.batched.opt$"
+ "^pnoise-reg.regress.batched.opt$"
+ "^pnoise.batched$"
+ "^pointcloud.batched$"
+ "^pointcloud.batched.opt$"
+ "^regex-reg.regress.batched.opt$"
+ "^select.batched$"
+ "^select.batched.opt$"
+ "^shaderglobals.batched$"
+ "^shaderglobals.batched.opt$"
+ "^smoothstep-reg.regress.batched.opt$"
+ "^spline-derivbug.batched$"
+ "^spline-derivbug.batched.opt$"
+ "^spline.batched$"
+ "^spline.batched.opt$"
+ "^splineinverse-ident.batched$"
+ "^splineinverse-ident.batched.opt$"
+ "^split-reg.regress.batched.opt$"
+ "^string$"
+ "^string-reg.regress.batched.opt$"
+ "^string.batched$"
+ "^string.batched.opt$"
+ "^string.opt$"
+ "^string.opt.rs_bitcode$"
+ "^struct-array-mixture.batched$"
+ "^struct-array-mixture.batched.opt$"
+ "^struct.batched$"
+ "^test-fmt-matrixcolor.opt.rs_bitcode$"
+ "^testoptix-noise.optix.opt$"
+ "^testoptix-reparam.optix.opt$"
+ "^texture-environment-opts-reg.regress.batched.opt$"
+ "^texture-opts-reg.regress.batched.opt$"
+ "^texture-wrap.batched$"
+ "^texture-wrap.batched.opt$"
+ "^transcendental-reg.regress.batched.opt$"
+ "^transform$"
+ "^transform.batched$"
+ "^transform.batched.opt$"
+ "^transform.opt$"
+ "^transform.opt.rs_bitcode$"
+ "^transformc$"
+ "^transformc.batched.opt$"
+ "^transformc.opt$"
+ "^transformc.opt.rs_bitcode$"
+ "^transformc.rsbitcode.opt$"
+ "^trig$"
+ "^trig-reg.regress.batched.opt$"
+ "^trig.batched$"
+ "^trig.batched.opt$"
+ "^trig.opt$"
+ "^trig.opt.rs_bitcode$"
+ "^vecctr.batched$"
+ "^vecctr.batched.opt$"
+ "^vector$"
+ "^vector-reg.regress.batched.opt$"
+ "^vector.opt$"
+ "^vector.opt.rs_bitcode$"
+ "^wavelength_color.optix$"
+ "^wavelength_color.optix.fused$"
+ "^wavelength_color.optix.opt$"
+ "^xml-reg.regress.batched.opt$"
+
+ # diff
+ "^testoptix.optix.opt$"
+ )
+ fi
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ )
+
+ local -x DEBUG CXXFLAGS LD_LIBRARY_PATH DIR OSL_DIR OSL_SOURCE_DIR PYTHONPATH
+ DEBUG=1 # doubles the floating point tolerance
+ CXXFLAGS="-I${T}/usr/include"
+ LD_LIBRARY_PATH="${T}/usr/$(get_libdir)"
+ OSL_DIR="${T}/usr/$(get_libdir)/cmake/OSL"
+ OSL_SOURCE_DIR="${S}"
+
+ if use python; then
+ PYTHONPATH="${BUILD_DIR}/lib/python/site-packages"
+ fi
+
+ cmake_src_test
+
+ CMAKE_SKIP_TESTS=(
+ "^render-background$"
+ "^render-mx-furnace-sheen$"
+ "^render-mx-burley-diffuse$"
+ "^render-mx-conductor$"
+ "^render-microfacet$"
+ "^render-veachmis$"
+ "^render-ward$"
+ "^render-raytypes.opt$"
+ "^render-raytypes.opt.rs_bitcode$"
+ )
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ --repeat until-pass:10
+ -R "^render"
+ )
+
+ cmake_src_test
+}
diff --git a/media-libs/osl/osl-9999.ebuild b/media-libs/osl/osl-9999.ebuild
new file mode 100644
index 000000000000..9ae3ddb5a40d
--- /dev/null
+++ b/media-libs/osl/osl-9999.ebuild
@@ -0,0 +1,443 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+PYTHON_COMPAT=( python3_{10..12} )
+
+# Check this on updates
+LLVM_COMPAT=( {15..17} )
+
+inherit cmake cuda flag-o-matic llvm-r1 toolchain-funcs python-single-r1
+
+DESCRIPTION="Advanced shading language for production GI renderers"
+HOMEPAGE="https://www.imageworks.com/technology/opensource https://github.com/AcademySoftwareFoundation/OpenShadingLanguage"
+
+if [[ ${PV} = *9999* ]] ; then
+ inherit git-r3
+ EGIT_REPO_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage.git"
+else
+ # If a development release, please don't keyword!
+ SRC_URI="https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/archive/v${PV}.tar.gz -> ${P}.tar.gz"
+ KEYWORDS="~amd64 ~arm ~arm64 ~ppc64"
+fi
+
+S="${WORKDIR}/OpenShadingLanguage-${PV}"
+
+LICENSE="BSD"
+SLOT="0/$(ver_cut 1-3)"
+
+X86_CPU_FEATURES=(
+ sse2:sse2 sse3:sse3 ssse3:ssse3 sse4_1:sse4.1 sse4_2:sse4.2
+ avx:avx avx2:avx2 avx512f:avx512f f16c:f16c
+)
+CPU_FEATURES=( "${X86_CPU_FEATURES[@]/#/cpu_flags_x86_}" )
+
+IUSE="doc gui libcxx nofma optix partio qt6 test ${CPU_FEATURES[*]%:*} python"
+RESTRICT="!test? ( test )"
+REQUIRED_USE="${PYTHON_REQUIRED_USE}"
+
+# TODO optix
+RDEPEND="
+ dev-libs/boost:=
+ dev-libs/pugixml
+ >=media-libs/openexr-3:0=
+ >=media-libs/openimageio-2.4:=
+ $(llvm_gen_dep '
+ sys-devel/clang:${LLVM_SLOT}
+ sys-devel/llvm:${LLVM_SLOT}
+ ')
+ sys-libs/zlib:=
+ optix? ( dev-libs/optix[-headers-only] )
+ python? (
+ ${PYTHON_DEPS}
+ $(python_gen_cond_dep '
+ dev-python/pybind11[${PYTHON_USEDEP}]
+ media-libs/openimageio[python,${PYTHON_SINGLE_USEDEP}]
+ ')
+ )
+ partio? ( media-libs/partio )
+ gui? (
+ !qt6? (
+ dev-qt/qtcore:5
+ dev-qt/qtgui:5
+ dev-qt/qtwidgets:5
+ dev-qt/qtopengl:5
+ )
+ qt6? (
+ dev-qt/qtbase:6[gui,widgets,opengl]
+ )
+ )
+"
+
+DEPEND="${RDEPEND}"
+BDEPEND="
+ sys-devel/bison
+ sys-devel/flex
+ virtual/pkgconfig
+"
+
+pkg_setup() {
+ llvm-r1_pkg_setup
+
+ use python && python-single-r1_pkg_setup
+}
+
+src_prepare() {
+ if use optix; then
+ cuda_src_prepare
+ cuda_add_sandbox -w
+ fi
+
+ sed -e "/^install.*llvm_macros.cmake.*cmake/d" -i CMakeLists.txt || die
+
+ cmake_src_prepare
+}
+
+src_configure() {
+ # pick the highest we support
+ local mysimd=()
+ if use cpu_flags_x86_avx512f; then
+ mysimd+=( avx512f )
+ elif use cpu_flags_x86_avx2 ; then
+ mysimd+=( avx2 )
+ if use cpu_flags_x86_f16c ; then
+ mysimd+=( f16c )
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mysimd+=( avx )
+ elif use cpu_flags_x86_sse4_2 ; then
+ mysimd+=( sse4.2 )
+ elif use cpu_flags_x86_sse4_1 ; then
+ mysimd+=( sse4.1 )
+ elif use cpu_flags_x86_ssse3 ; then
+ mysimd+=( ssse3 )
+ elif use cpu_flags_x86_sse3 ; then
+ mysimd+=( sse3 )
+ elif use cpu_flags_x86_sse2 ; then
+ mysimd+=( sse2 )
+ fi
+
+ local mybatched=()
+ if use cpu_flags_x86_avx512f || use cpu_flags_x86_avx2 ; then
+ if use cpu_flags_x86_avx512f ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX512_noFMA"
+ "b16_AVX512_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX512"
+ "b16_AVX512"
+ )
+ fi
+ fi
+ if use cpu_flags_x86_avx2 ; then
+ if use nofma; then
+ mybatched+=(
+ "b8_AVX2_noFMA"
+ )
+ else
+ mybatched+=(
+ "b8_AVX2"
+ )
+ fi
+ fi
+ elif use cpu_flags_x86_avx ; then
+ mybatched+=(
+ "b8_AVX"
+ )
+ fi
+
+ # If no CPU SIMDs were used, completely disable them
+ [[ -z "${mysimd[*]}" ]] && mysimd=("0")
+ [[ -z "${mybatched[*]}" ]] && mybatched=("0")
+
+ # This is currently needed on arm64 to get the NEON SIMD wrapper to compile the code successfully
+ # Even if there are no SIMD features selected, it seems like the code will turn on NEON support if it is available.
+ use arm64 && append-flags -flax-vector-conversions
+
+ local gcc
+ gcc="$(tc-getCC)"
+
+ local mycmakeargs=(
+ -DCMAKE_POLICY_DEFAULT_CMP0146="OLD" # BUG FindCUDA
+ -DCMAKE_POLICY_DEFAULT_CMP0148="OLD" # BUG FindPythonInterp
+
+ # std::tuple_size_v is c++17
+ -DCMAKE_CXX_STANDARD="17"
+
+ -DCMAKE_INSTALL_DOCDIR="share/doc/${PF}"
+ -DINSTALL_DOCS="$(usex doc)"
+ -DUSE_CCACHE="no"
+ -DLLVM_STATIC="no"
+ -DOSL_BUILD_TESTS="$(usex test)"
+ -DSTOP_ON_WARNING="no"
+ -DUSE_PARTIO="$(usex partio)"
+ -DUSE_PYTHON="$(usex python)"
+ -DPYTHON_VERSION="${EPYTHON/python}"
+ -DUSE_SIMD="$(IFS=","; echo "${mysimd[*]}")"
+ -DUSE_BATCHED="$(IFS=","; echo "${mybatched[*]}")"
+ -DUSE_LIBCPLUSPLUS="$(usex libcxx)"
+ -DOSL_USE_OPTIX="$(usex optix)"
+ -DVEC_REPORT="yes"
+
+ -DOpenImageIO_ROOT="${EPREFIX}/usr"
+ )
+
+ if use gui; then
+ mycmakeargs+=( -DUSE_QT="yes" )
+ if ! use qt6; then
+ mycmakeargs+=( -DCMAKE_DISABLE_FIND_PACKAGE_Qt6="yes" )
+ fi
+ else
+ mycmakeargs+=( -DUSE_QT="no" )
+ fi
+
+ if use optix; then
+ mycmakeargs+=(
+ -DOptiX_FIND_QUIETLY="no"
+ -DCUDA_FIND_QUIETLY="no"
+
+ -DOPTIXHOME="${EPREFIX}/opt/optix"
+ -DCUDA_TOOLKIT_ROOT_DIR="${EPREFIX}/opt/cuda"
+
+ -DCUDA_NVCC_FLAGS="--compiler-bindir;$(cuda_gccdir)"
+ -DOSL_EXTRA_NVCC_ARGS="--compiler-bindir;$(cuda_gccdir)"
+ -DCUDA_VERBOSE_BUILD="yes"
+ )
+ fi
+
+ if use partio; then
+ mycmakeargs+=(
+ -Dpartio_DIR="${EPREFIX}/usr"
+ )
+ fi
+
+ cmake_src_configure
+}
+
+src_test() {
+ # A bunch of tests only work when installed.
+ # So install them into the temp directory now.
+ DESTDIR="${T}" cmake_build install
+
+ ln -s "${CMAKE_USE_DIR}/src/cmake/" "${BUILD_DIR}/src/cmake" || die
+
+ if use optix; then
+ cp \
+ "${BUILD_DIR}/src/liboslexec/shadeops_cuda.ptx" \
+ "${BUILD_DIR}/src/testrender/"{optix_raytracer,quad,rend_lib_testrender,sphere,wrapper}".ptx" \
+ "${BUILD_DIR}/src/testshade/"{optix_grid_renderer,rend_lib_testshade}".ptx" \
+ "${BUILD_DIR}/bin/" || die
+
+ # NOTE this should go to cuda eclass
+ addwrite /dev/nvidiactl
+ addwrite /dev/nvidia0
+ addwrite /dev/nvidia-uvm
+ addwrite /dev/nvidia-caps
+ addwrite "/dev/char/"
+ fi
+
+ CMAKE_SKIP_TESTS=(
+ "broken"
+ "^render"
+
+ # broken with in-tree <=dev-libs/optix-7.5.0 and out of date
+ "^example-cuda$"
+
+ # outright fail
+ "^transform-reg.regress.batched.opt$"
+
+ # SIGABRT similar to https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/issues/1363
+ "^derivs.opt.rs_bitcode$"
+ "^geomath.batched$"
+ "^matrix.batched$"
+ "^matrix.batched.opt$"
+ "^spline-reg.regress.batched.opt$"
+ "^transformc.batched$"
+ )
+
+ # These only fail inside sandbox
+ if [[ "${OSL_OPTIONAL_TESTS}" != "true" ]]; then
+ CMAKE_SKIP_TESTS+=(
+ # TODO: investigate failures
+ # SIGABRT similar to https://github.com/AcademySoftwareFoundation/OpenShadingLanguage/issues/1363
+ "^andor-reg.regress.batched.opt$"
+ "^arithmetic-reg.regress.batched.opt$"
+ "^array-assign-reg.regress.batched.opt$"
+ "^array-copy-reg.regress.batched.opt$"
+ "^array-length-reg.regress.batched$"
+ "^closure-parameters.batched$"
+ "^closure-parameters.batched.opt$"
+ "^closure.batched$"
+ "^closure.batched.opt$"
+ "^debug-uninit$"
+ "^debug-uninit.batched$"
+ "^debug-uninit.batched.opt$"
+ "^debug-uninit.opt$"
+ "^debug-uninit.opt.rs_bitcode$"
+ "^derivs$"
+ "^derivs.batched$"
+ "^derivs.batched.opt$"
+ "^derivs.opt$"
+ "^exponential$"
+ "^exponential.opt$"
+ "^exponential.opt.rs_bitcode$"
+ "^filterwidth-reg.regress.batched.opt$"
+ "^geomath$"
+ "^geomath.batched.opt$"
+ "^geomath.opt$"
+ "^geomath.opt.rs_bitcode$"
+ "^getattribute-camera.batched$"
+ "^getattribute-camera.batched.opt$"
+ "^getattribute-shader.batched.opt$"
+ "^gettextureinfo-reg.regress.batched.opt$"
+ "^gettextureinfo-udim-reg.regress.batched.opt$"
+ "^gettextureinfo.batched$"
+ "^hyperb.batched.opt$"
+ "^hyperb.opt$"
+ "^hyperb.opt.rs_bitcode$"
+ "^initlist.batched$"
+ "^initlist.batched.opt$"
+ "^linearstep.batched$"
+ "^linearstep.batched.opt$"
+ "^loop.batched$"
+ "^loop.batched.opt$"
+ "^matrix$"
+ "^matrix-compref-reg.regress.batched.opt$"
+ "^matrix-reg.regress.rsbitcode.opt$"
+ "^matrix.opt$"
+ "^matrix.opt.rs_bitcode$"
+ "^matrix.rsbitcode.opt$"
+ "^message-no-closure.batched$"
+ "^message-no-closure.batched.opt$"
+ "^message-reg.regress.batched.opt$"
+ "^miscmath$"
+ "^miscmath.batched$"
+ "^miscmath.batched.opt$"
+ "^miscmath.opt$"
+ "^miscmath.opt.rs_bitcode$"
+ "^noise-cell.batched$"
+ "^noise-gabor-reg.regress.batched.opt$"
+ "^noise-gabor.batched$"
+ "^noise-gabor.batched.opt$"
+ "^noise-generic.batched$"
+ "^noise-generic.batched.opt$"
+ "^noise-perlin.batched$"
+ "^noise-perlin.batched.opt$"
+ "^noise-reg.regress.batched.opt$"
+ "^noise-simplex.batched$"
+ "^noise-simplex.batched.opt$"
+ "^noise.batched$"
+ "^opt-warnings.batched$"
+ "^opt-warnings.batched.opt$"
+ "^pnoise-cell.batched$"
+ "^pnoise-gabor.batched$"
+ "^pnoise-gabor.batched.opt$"
+ "^pnoise-generic.batched$"
+ "^pnoise-generic.batched.opt$"
+ "^pnoise-perlin.batched$"
+ "^pnoise-perlin.batched.opt$"
+ "^pnoise-reg.regress.batched.opt$"
+ "^pnoise.batched$"
+ "^pointcloud.batched$"
+ "^pointcloud.batched.opt$"
+ "^regex-reg.regress.batched.opt$"
+ "^select.batched$"
+ "^select.batched.opt$"
+ "^shaderglobals.batched$"
+ "^shaderglobals.batched.opt$"
+ "^smoothstep-reg.regress.batched.opt$"
+ "^spline-derivbug.batched$"
+ "^spline-derivbug.batched.opt$"
+ "^spline.batched$"
+ "^spline.batched.opt$"
+ "^splineinverse-ident.batched$"
+ "^splineinverse-ident.batched.opt$"
+ "^split-reg.regress.batched.opt$"
+ "^string$"
+ "^string-reg.regress.batched.opt$"
+ "^string.batched$"
+ "^string.batched.opt$"
+ "^string.opt$"
+ "^string.opt.rs_bitcode$"
+ "^struct-array-mixture.batched$"
+ "^struct-array-mixture.batched.opt$"
+ "^struct.batched$"
+ "^test-fmt-matrixcolor.opt.rs_bitcode$"
+ "^testoptix-noise.optix.opt$"
+ "^testoptix-reparam.optix.opt$"
+ "^texture-environment-opts-reg.regress.batched.opt$"
+ "^texture-opts-reg.regress.batched.opt$"
+ "^texture-wrap.batched$"
+ "^texture-wrap.batched.opt$"
+ "^transcendental-reg.regress.batched.opt$"
+ "^transform$"
+ "^transform.batched$"
+ "^transform.batched.opt$"
+ "^transform.opt$"
+ "^transform.opt.rs_bitcode$"
+ "^transformc$"
+ "^transformc.batched.opt$"
+ "^transformc.opt$"
+ "^transformc.opt.rs_bitcode$"
+ "^transformc.rsbitcode.opt$"
+ "^trig$"
+ "^trig-reg.regress.batched.opt$"
+ "^trig.batched$"
+ "^trig.batched.opt$"
+ "^trig.opt$"
+ "^trig.opt.rs_bitcode$"
+ "^vecctr.batched$"
+ "^vecctr.batched.opt$"
+ "^vector$"
+ "^vector-reg.regress.batched.opt$"
+ "^vector.opt$"
+ "^vector.opt.rs_bitcode$"
+ "^xml-reg.regress.batched.opt$"
+ # diff
+ "^testoptix.optix.opt$"
+ )
+ fi
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ )
+
+ local -x DEBUG CXXFLAGS LD_LIBRARY_PATH DIR OSL_DIR OSL_SOURCE_DIR PYTHONPATH
+ DEBUG=1 # doubles the floating point tolerance
+ CXXFLAGS="-I${T}/usr/include"
+ LD_LIBRARY_PATH="${T}/usr/$(get_libdir)"
+ OSL_DIR="${T}/usr/$(get_libdir)/cmake/OSL"
+ OSL_SOURCE_DIR="${S}"
+
+ if use python; then
+ PYTHONPATH="${BUILD_DIR}/lib/python/site-packages"
+ fi
+
+ cmake_src_test
+
+ CMAKE_SKIP_TESTS=(
+ "^render-background$"
+ "^render-mx-furnace-sheen$"
+ "^render-mx-burley-diffuse$"
+ "^render-mx-conductor$"
+ "^render-microfacet$"
+ "^render-veachmis$"
+ "^render-ward$"
+ "^render-raytypes.opt$"
+ "^render-raytypes.opt.rs_bitcode$"
+ )
+
+ myctestargs=(
+ # src/build-scripts/ci-test.bash
+ '--force-new-ctest-process'
+ --repeat until-pass:10
+ -R "^render"
+ )
+
+ cmake_src_test
+}