commit:     d0f4981ea796fc2aa053659bc7a0b45d9f652eb9
Author:     Marius Brehler <marbre <AT> linux <DOT> sungazer <DOT> de>
AuthorDate: Thu Mar 19 08:06:10 2015 +0000
Commit:     Christoph Junghans <ottxor <AT> gentoo <DOT> org>
CommitDate: Thu Mar 19 08:06:10 2015 +0000
URL:        https://gitweb.gentoo.org/proj/sci.git/commit/?id=d0f4981e

dev-util/nvidia-cuda-toolkit: Version bump

Package-Manager: portage-2.2.14

 dev-util/nvidia-cuda-toolkit/ChangeLog             |   8 +-
 .../nvidia-cuda-toolkit-7.0.28.ebuild              | 143 +++++++++++++++++++++
 2 files changed, 150 insertions(+), 1 deletion(-)

diff --git a/dev-util/nvidia-cuda-toolkit/ChangeLog 
b/dev-util/nvidia-cuda-toolkit/ChangeLog
index 07be9bc..c079b7e 100644
--- a/dev-util/nvidia-cuda-toolkit/ChangeLog
+++ b/dev-util/nvidia-cuda-toolkit/ChangeLog
@@ -1,6 +1,12 @@
 # Copyright 1999-2015 Gentoo Foundation; Distributed under the GPL v2
 # $Header: $
 
+*nvidia-cuda-toolkit-7.0.28 (19 Mar 2015)
+
+  19 Mar 2015; Marius Brehler <[email protected]>
+  +nvidia-cuda-toolkit-7.0.28.ebuild:
+  Version bump
+
 *nvidia-cuda-toolkit-7.0.18-r1 (19 Feb 2015)
 
   19 Feb 2015; Justin Lecher <[email protected]>
@@ -12,4 +18,4 @@
   14 Jan 2014; Marius Brehler <[email protected]> +files/cuda-config.in,
   +metadata.xml, +nvidia-cuda-toolkit-7.0.18.ebuild:
   Add version 7.0.18 (release candidate)
-  
\ No newline at end of file
+  

diff --git a/dev-util/nvidia-cuda-toolkit/nvidia-cuda-toolkit-7.0.28.ebuild 
b/dev-util/nvidia-cuda-toolkit/nvidia-cuda-toolkit-7.0.28.ebuild
new file mode 100644
index 0000000..955d8a5
--- /dev/null
+++ b/dev-util/nvidia-cuda-toolkit/nvidia-cuda-toolkit-7.0.28.ebuild
@@ -0,0 +1,143 @@
+# Copyright 1999-2015 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI=5
+
+inherit check-reqs cuda unpacker versionator
+
+MYD=$(get_version_component_range 1)_$(get_version_component_range 2)
+
+DESCRIPTION="NVIDIA CUDA Toolkit (compiler and friends)"
+HOMEPAGE="http://developer.nvidia.com/cuda";
+SRC_URI="http://developer.download.nvidia.com/compute/cuda/${MYD}/Prod/local_installers/cuda_${PV}_linux.run";
+
+SLOT="0/${PV}"
+LICENSE="NVIDIA-CUDA"
+KEYWORDS="-* ~amd64 ~amd64-linux"
+IUSE="debugger doc eclipse profiler"
+
+DEPEND=""
+RDEPEND="${DEPEND}
+       >=sys-devel/gcc-4.7[cxx]
+       >=x11-drivers/nvidia-drivers-346.35[uvm]
+       debugger? (
+               sys-libs/libtermcap-compat
+               sys-libs/ncurses[tinfo]
+               )
+       eclipse? ( >=virtual/jre-1.6 )
+       profiler? ( >=virtual/jre-1.6 )"
+
+S="${WORKDIR}"
+
+QA_PREBUILT="opt/cuda/*"
+
+CHECKREQS_DISK_BUILD="1500M"
+
+pkg_setup() {
+       # We don't like to run cuda_pkg_setup as it depends on us
+       check-reqs_pkg_setup
+}
+
+src_unpack() {
+       unpacker
+       unpacker run_files/cuda-linux*.run
+}
+
+src_prepare() {
+       local cuda_supported_gcc
+
+       cuda_supported_gcc="4.7 4.8 4.9"
+
+       sed \
+               -e "s:CUDA_SUPPORTED_GCC:${cuda_supported_gcc}:g" \
+               "${FILESDIR}"/cuda-config.in > "${T}"/cuda-config || die
+}
+
+src_install() {
+       local i j
+       local remove="doc jre run_files install-linux.pl "
+       local cudadir=/opt/cuda
+       local ecudadir="${EPREFIX}"${cudadir}
+
+       # dodoc doc/*txt
+       if use doc; then
+               dodoc doc/pdf/*
+               dohtml -r doc/html/*
+       fi
+
+       mv doc/man/man3/{,cuda-}deprecated.3 || die
+       doman doc/man/man*/*
+
+       use debugger || remove+=" bin/cuda-gdb extras/Debugger"
+       ( use profiler || use eclipse ) || remove+=" libnsight"
+       remove+=" cuda-installer.pl"
+
+       if use profiler; then
+               # hack found in install-linux.pl
+               for j in nvvp nsight; do
+                       cat > bin/${j} <<- EOF
+                               #!${EPREFIX}/bin/sh
+                               
LD_LIBRARY_PATH=\${LD_LIBRARY_PATH}:${ecudadir}/lib:${ecudadir}/lib64 \
+                                       UBUNTU_MENUPROXY=0 
LIBOVERLAY_SCROLLBAR=0 \
+                                       ${ecudadir}/lib${j}/${j} -vm 
${EPREFIX}/usr/bin/java
+                       EOF
+                       chmod a+x bin/${j}
+               done
+       else
+               use eclipse || remove+=" libnvvp"
+               remove+=" extras/CUPTI"
+       fi
+
+       for i in ${remove}; do
+       ebegin "Cleaning ${i}..."
+               if [[ -e ${i} ]]; then
+                       find ${i} -delete || die
+                       eend
+               else
+                       eend $1
+               fi
+       done
+
+       ln -sf lib lib32 || die
+
+       dodir ${cudadir}
+       mv * "${ED}"${cudadir} || die
+
+       cat > "${T}"/99cuda <<- EOF
+               PATH=${ecudadir}/bin$(use profiler && echo 
":${ecudadir}/libnvvp")
+               ROOTPATH=${ecudadir}/bin
+               LDPATH=${ecudadir}/lib64:${ecudadir}/lib
+       EOF
+       doenvd "${T}"/99cuda
+
+       use profiler && \
+               make_wrapper nvprof "${EPREFIX}"${cudadir}/bin/nvprof "." 
${ecudadir}/lib64:${ecudadir}/lib
+
+       dobin "${T}"/cuda-config
+}
+
+pkg_postinst_check() {
+       local a b
+       a="$(version_sort $(cuda-config -s))"; a=( $a )
+       # greatest supported version
+       b=${a[${#a[@]}-1]}
+
+       # if gcc and if not gcc-version is at least greatesst supported
+       if [[ $(tc-getCC) == *gcc* ]] && \
+               ! version_is_at_least $(gcc-version) ${b}; then
+                       echo
+                       ewarn "gcc >= ${b} will not work with CUDA"
+                       ewarn "Make sure you set an earlier version of gcc with 
gcc-config"
+                       ewarn "or append --compiler-bindir= pointing to a gcc 
bindir like"
+                       ewarn 
"--compiler-bindir=${EPREFIX}/usr/*pc-linux-gnu/gcc-bin/gcc${b}"
+                       ewarn "to the nvcc compiler flags"
+                       echo
+       fi
+}
+
+pkg_postinst() {
+       if [[ ${MERGE_TYPE} != binary ]]; then
+               pkg_postinst_check
+       fi
+}

Reply via email to