commit: 2686aee327716ccc1768f41cde0979a9441c4ad0
Author: Jeroen Roovers <jer <AT> gentoo <DOT> org>
AuthorDate: Sat Jan 30 11:47:05 2016 +0000
Commit: Jeroen Roovers <jer <AT> gentoo <DOT> org>
CommitDate: Sat Jan 30 11:47:05 2016 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=2686aee3
x11-drivers/nvidia-drivers: USE=static-libs requires USE=tools. Update 352
branch for bug #562910.
Package-Manager: portage-2.2.27
x11-drivers/nvidia-drivers/Manifest | 1 +
.../nvidia-drivers-304.131-r1.ebuild | 5 +-
...1-r1.ebuild => nvidia-drivers-352.79-r1.ebuild} | 148 +++++++++++++--------
.../nvidia-drivers/nvidia-drivers-361.18-r2.ebuild | 14 +-
4 files changed, 105 insertions(+), 63 deletions(-)
diff --git a/x11-drivers/nvidia-drivers/Manifest
b/x11-drivers/nvidia-drivers/Manifest
index 13b7ae7..00809e0 100644
--- a/x11-drivers/nvidia-drivers/Manifest
+++ b/x11-drivers/nvidia-drivers/Manifest
@@ -42,4 +42,5 @@ DIST NVIDIA-Linux-x86_64-361.18.run 86447500 SHA256
94cccc3ff10ee9544f60bf1d32d0
DIST NVIDIA-Linux-x86_64-96.43.23-pkg2.run 15962375 SHA256
ce8d8253e7dab7da63fbdac449ebf190cd0c10cbfffea0f8d0165515f851bc64 SHA512
04bec1187a6024a2b9839f008ec829281f1f2602dae2e639030bc385943186506bcaa2b46a230b2ab87f9217190841abc62f9e2d6395ab5559623389c31c6563
WHIRLPOOL
0651c44a51a1a06fcff5bfddbf9c3e408977e03263c7fe806cb6c01f9fe92f716dfe4e5190ffe1048bde72fcffdc8bca8267e74dd43ba5c9dfb22b6201fcc2bb
DIST nvidia-settings-304.131.tar.bz2 1480447 SHA256
d36d2d1ae7c1bb72cd18e713470546d2aa7057624b1f61319daf559a94054d29 SHA512
9269f54f87581e29e6d7cabeaf989c70cb27aa55f6b8f5f1c71b8a14401326d06ea194710722b41283cca56f5808b90a9b1fb12158d48c6332cce15a701c5796
WHIRLPOOL
be8e38a09a0bfa40267b9cdae2800a9ef00a89e28e618b743b7acb0cd9ece4b242b74ced32018d735989592300b49b2ee683caa11a1e161bcecf070a58952dfd
DIST nvidia-settings-340.96.tar.bz2 1551011 SHA256
af7303b070a4b41e388a7be6dfae17f020a5cc197170d4815b9a291a3a98aaff SHA512
fc6096338e48c347e4e854d06e8f63d8edb6527953996e63f3f70619be59d0436176547b5197ef30d18a82cf5b58dd775dcca4a2624107b63cce1ae589f2b154
WHIRLPOOL
e7266ca0395aa1a5666a43bf6e54e258706d4e76bfd15079485e2379b332d2d6ba0c97b32e49f5b041340bb2d3c0e11dace702754ffc952c149557e0ab9d820a
+DIST nvidia-settings-352.79.tar.bz2 1570988 SHA256
1f103cbfe162281355c484a5c3ef9ac1bb0528acba2d229111da7e58cf18f217 SHA512
d56e20844bf71d55e51aebca38e922a2985fdbd4edab29a07f9a4a8a0b883ca469c3b949f048837ec77464da90e2d485e5efcd314afc2810c44ad7dc497b53fe
WHIRLPOOL
51999a744f6b3e36c4d12f841c136a754533de09c1802f60392666392beeccbb0bf1489269cac33b12ccb061554609d3dc8d8ffbf45b4cb860108fd9f86e2139
DIST nvidia-settings-361.18.tar.bz2 1570821 SHA256
5e821bf9c92931da7c4ac2cac4c61a83e7f74641902935232cad747511fab363 SHA512
1a19ebb6773b53564a7996c8f963c161df599ed8ca577f505fbed1181f144a5e53fa970e3fee7fceed16909bd012f74f9af74080314ae9de9356894df9b1be4d
WHIRLPOOL
23ff413900fca81427d755ecb5889dbb69033e101cf7c2f3edea4971defd03aedee95f5488779f634c690c05bfabe0763baf3dbf6377de950cabe48ad9c72684
diff --git a/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
b/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
index 50aa106..4de38e1 100644
--- a/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
+++ b/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
@@ -65,7 +65,10 @@ RDEPEND="${COMMON}
"
PDEPEND="X? ( >=x11-libs/libvdpau-0.3-r1 )"
-REQUIRED_USE="tools? ( X )"
+REQUIRED_USE="
+ tools? ( X )
+ static-libs? ( tools )
+"
QA_PREBUILT="opt/* usr/lib*"
diff --git a/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
b/x11-drivers/nvidia-drivers/nvidia-drivers-352.79-r1.ebuild
similarity index 79%
copy from x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
copy to x11-drivers/nvidia-drivers/nvidia-drivers-352.79-r1.ebuild
index 50aa106..2435263 100644
--- a/x11-drivers/nvidia-drivers/nvidia-drivers-304.131-r1.ebuild
+++ b/x11-drivers/nvidia-drivers/nvidia-drivers-352.79-r1.ebuild
@@ -3,8 +3,9 @@
# $Id$
EAPI=5
+
inherit eutils flag-o-matic linux-info linux-mod multilib nvidia-driver \
- portability toolchain-funcs unpacker user versionator udev
+ portability toolchain-funcs unpacker user udev
NV_URI="http://us.download.nvidia.com/XFree86/"
X86_NV_PACKAGE="NVIDIA-Linux-x86-${PV}"
@@ -22,57 +23,65 @@ SRC_URI="
tools? (
ftp://download.nvidia.com/XFree86/nvidia-settings/nvidia-settings-${PV}.tar.bz2
)
"
-LICENSE="GPL-2 NVIDIA-r1"
+LICENSE="GPL-2 NVIDIA-r2"
SLOT="0/${PV%.*}"
KEYWORDS="-* ~amd64 ~x86 ~amd64-fbsd ~x86-fbsd"
-IUSE="acpi multilib kernel_FreeBSD kernel_linux pax_kernel static-libs +tools
+X"
RESTRICT="bindist mirror strip"
EMULTILIB_PKG="true"
+IUSE="acpi gtk3 multilib kernel_FreeBSD kernel_linux pax_kernel static-libs
+tools +X uvm"
+REQUIRED_USE="
+ tools? ( X )
+ static-libs? ( tools )
+"
+
COMMON="
app-eselect/eselect-opencl
kernel_linux? ( >=sys-libs/glibc-2.6.1 )
tools? (
dev-libs/atk
dev-libs/glib:2
- x11-libs/gdk-pixbuf
+ dev-libs/jansson
+ gtk3? (
+ x11-libs/gtk+:3
+ )
+ x11-libs/cairo
+ x11-libs/gdk-pixbuf[X]
x11-libs/gtk+:2
x11-libs/libX11
x11-libs/libXext
+ x11-libs/libXrandr
+ x11-libs/libXv
+ x11-libs/libXxf86vm
x11-libs/pango[X]
- x11-libs/pangox-compat
)
X? (
>=app-eselect/eselect-opengl-1.0.9
)
"
-DEPEND="${COMMON}
- kernel_linux? (
- virtual/linux-sources
- virtual/pkgconfig
- )"
-RDEPEND="${COMMON}
+DEPEND="
+ ${COMMON}
+ kernel_linux? ( virtual/linux-sources )
+"
+RDEPEND="
+ ${COMMON}
acpi? ( sys-power/acpid )
tools? ( !media-video/nvidia-settings )
X? (
<x11-base/xorg-server-1.18.99:=
- x11-libs/libXvMC
+ >=x11-libs/libvdpau-0.3-r1
multilib? (
>=x11-libs/libX11-1.6.2[abi_x86_32]
>=x11-libs/libXext-1.3.2[abi_x86_32]
)
)
"
-PDEPEND="X? ( >=x11-libs/libvdpau-0.3-r1 )"
-
-REQUIRED_USE="tools? ( X )"
QA_PREBUILT="opt/* usr/lib*"
S=${WORKDIR}/
pkg_pretend() {
-
if use amd64 && has_multilib_profile && \
[ "${DEFAULT_ABI}" != "amd64" ]; then
eerror "This ebuild doesn't currently support changing your
default ABI"
@@ -113,10 +122,17 @@ pkg_setup() {
export CCACHE_DISABLE=1
if use kernel_linux; then
- linux-mod_pkg_setup
MODULE_NAMES="nvidia(video:${S}/kernel)"
+ use uvm && MODULE_NAMES+=" nvidia-uvm(video:${S}/kernel/uvm)"
+
+ # This needs to run after MODULE_NAMES (so that the eclass
checks
+ # whether the kernel supports loadable modules) but before
BUILD_PARAMS
+ # is set (so that KV_DIR is populated).
+ linux-mod_pkg_setup
+
BUILD_PARAMS="IGNORE_CC_MISMATCH=yes V=1 SYSSRC=${KV_DIR} \
SYSOUT=${KV_OUT_DIR} CC=$(tc-getBUILD_CC)"
+
# linux-mod_src_compile calls set_arch_to_kernel, which
# sets the ARCH to x86 but NVIDIA's wrapping Makefile
# expects x86_64 or i386 and then converts it to x86
@@ -155,21 +171,17 @@ src_prepare() {
fi
# If greater than 2.6.5 use M= instead of SUBDIR=
- convert_to_m "${NV_SRC}"/Makefile.kbuild
+# convert_to_m "${NV_SRC}"/Makefile.kbuild
fi
if use pax_kernel; then
ewarn "Using PAX patches is not supported. You will be asked to"
ewarn "use a standard kernel should you have issues. Should you"
ewarn "need support with these patches, contact the PaX team."
- epatch "${FILESDIR}"/${PN}-pax-const.patch
- epatch "${FILESDIR}"/${PN}-pax-usercopy.patch
+ epatch "${FILESDIR}"/${PN}-346.16-pax-usercopy.patch
+ epatch "${FILESDIR}"/${PN}-346.16-pax-constify.patch
fi
- cat <<- EOF > "${S}"/nvidia.icd
- /usr/$(get_libdir)/libnvidia-opencl.so
- EOF
-
# Allow user patches so they can support RC kernels and whatever else
epatch_user
}
@@ -184,25 +196,26 @@ src_compile() {
MAKE="$(get_bmake)" CFLAGS="-Wno-sign-compare" emake
CC="$(tc-getCC)" \
LD="$(tc-getLD)" LDFLAGS="$(raw-ldflags)" || die
elif use kernel_linux; then
- MAKEOPTS=-j1 linux-mod_src_compile
+ MAKEOPTS=-j1
+ linux-mod_src_compile
fi
if use tools; then
- emake -C "${S}"/nvidia-settings-${PV}/src/libXNVCtrl clean
- emake -C "${S}"/nvidia-settings-${PV}/src/libXNVCtrl \
+ emake -C "${S}"/nvidia-settings-${PV}/src \
AR="$(tc-getAR)" \
CC="$(tc-getCC)" \
+ LIBDIR="$(get_libdir)" \
RANLIB="$(tc-getRANLIB)" \
- libXNVCtrl.a
+ build-xnvctrl
+
emake -C "${S}"/nvidia-settings-${PV}/src \
- AR="$(tc-getAR)" \
CC="$(tc-getCC)" \
+ GTK3_AVAILABLE=$(usex gtk3 1 0) \
LD="$(tc-getCC)" \
LIBDIR="$(get_libdir)" \
NVML_ENABLED=0 \
NV_USE_BUNDLED_LIBJANSSON=0 \
NV_VERBOSE=1 \
- RANLIB="$(tc-getRANLIB)" \
STRIP_CMD=true
fi
}
@@ -258,6 +271,7 @@ src_install() {
# pkg_preinst, see bug #491414
insinto /etc/modprobe.d
newins "${FILESDIR}"/nvidia-169.07 nvidia.conf
+ use uvm && doins "${FILESDIR}"/nvidia-uvm.conf
# Ensures that our device nodes are created when not using X
exeinto "$(get_udevdir)"
@@ -276,9 +290,13 @@ src_install() {
# NVIDIA kernel <-> userspace driver config lib
donvidia ${NV_OBJ}/libnvidia-cfg.so ${NV_SOVER}
+ # NVIDIA framebuffer capture library
+ donvidia ${NV_OBJ}/libnvidia-fbc.so ${NV_SOVER}
+
+ # NVIDIA video encode/decode <-> CUDA
if use kernel_linux; then
- # NVIDIA video decode <-> CUDA
donvidia ${NV_OBJ}/libnvcuvid.so ${NV_SOVER}
+ donvidia ${NV_OBJ}/libnvidia-encode.so ${NV_SOVER}
fi
if use X; then
@@ -290,20 +308,17 @@ src_install() {
donvidia ${NV_X11}/libglx.so ${NV_SOVER} \
/usr/$(get_libdir)/opengl/nvidia/extensions
- # XvMC driver
- dolib.a ${NV_X11}/libXvMCNVIDIA.a || \
- die "failed to install libXvMCNVIDIA.so"
- donvidia ${NV_X11}/libXvMCNVIDIA.so ${NV_SOVER}
- dosym libXvMCNVIDIA.so.${NV_SOVER} \
- /usr/$(get_libdir)/libXvMCNVIDIA_dynamic.so.1 || \
- die "failed to create libXvMCNVIDIA_dynamic.so symlink"
+ # Xorg nvidia.conf
+ if has_version '>=x11-base/xorg-server-1.16'; then
+ insinto /usr/share/X11/xorg.conf.d
+ newins {,50-}nvidia-drm-outputclass.conf
+ fi
fi
# OpenCL ICD for NVIDIA
if use kernel_linux; then
insinto /etc/OpenCL/vendors
- doins nvidia.icd
- donvidia ${NV_OBJ}/libnvidia-opencl.so ${NV_SOVER}
+ doins ${NV_OBJ}/nvidia.icd
fi
# Documentation
@@ -319,7 +334,7 @@ src_install() {
doman "${NV_MAN}/nvidia-smi.1.gz"
use X && doman "${NV_MAN}/nvidia-xconfig.1.gz"
use tools && doman "${NV_MAN}/nvidia-settings.1.gz"
- doman "${NV_MAN}/nvidia-cuda-proxy-control.1.gz"
+ doman "${NV_MAN}/nvidia-cuda-mps-control.1.gz"
fi
# Helper Apps
@@ -330,19 +345,30 @@ src_install() {
fi
if use kernel_linux ; then
+ doexe ${NV_OBJ}/nvidia-cuda-mps-control
+ doexe ${NV_OBJ}/nvidia-cuda-mps-server
doexe ${NV_OBJ}/nvidia-debugdump
- doexe ${NV_OBJ}/nvidia-cuda-proxy-control
- doexe ${NV_OBJ}/nvidia-cuda-proxy-server
+ doexe ${NV_OBJ}/nvidia-persistenced
doexe ${NV_OBJ}/nvidia-smi
+
+ # install nvidia-modprobe setuid and symlink in /usr/bin (bug
#505092)
+ doexe ${NV_OBJ}/nvidia-modprobe
+ fowners root:video /opt/bin/nvidia-modprobe
+ fperms 4710 /opt/bin/nvidia-modprobe
+ dosym /{opt,usr}/bin/nvidia-modprobe
+
+ doman nvidia-cuda-mps-control.1.gz
+ doman nvidia-modprobe.1.gz
+ doman nvidia-persistenced.1.gz
newinitd "${FILESDIR}/nvidia-smi.init" nvidia-smi
+ newconfd "${FILESDIR}/nvidia-persistenced.conf"
nvidia-persistenced
+ newinitd "${FILESDIR}/nvidia-persistenced.init"
nvidia-persistenced
fi
- dobin ${NV_OBJ}/nvidia-bug-report.sh
-
- # Desktop entries for nvidia-settings
- if use tools ; then
+ if use tools; then
emake -C "${S}"/nvidia-settings-${PV}/src/ \
DESTDIR="${D}" \
+ GTK3_AVAILABLE=$(usex gtk3 1 0) \
LIBDIR="${D}/usr/$(get_libdir)" \
PREFIX=/usr \
NV_USE_BUNDLED_LIBJANSSON=0 \
@@ -351,8 +377,12 @@ src_install() {
use static-libs && \
dolib.a
"${S}"/nvidia-settings-${PV}/src/libXNVCtrl/libXNVCtrl.a
- insinto /usr/include/NVCtrl
- doins "${S}"/nvidia-settings-${PV}/src/libXNVCtrl/*.h
+ insinto /usr/share/nvidia/
+ doins nvidia-application-profiles-${PV}-key-documentation
+
+ insinto /etc/nvidia
+ newins \
+ nvidia-application-profiles-${PV}-rc
nvidia-application-profiles-rc
# There is no icon in the FreeBSD tarball.
use kernel_FreeBSD || \
@@ -364,7 +394,7 @@ src_install() {
doexe "${FILESDIR}"/95-nvidia-settings
fi
- #doenvd "${FILESDIR}"/50nvidia-prelink-blacklist
+ dobin ${NV_OBJ}/nvidia-bug-report.sh
if has_multilib_profile && use multilib ; then
local OABI=${ABI}
@@ -395,16 +425,27 @@ src_install-libs() {
if use X; then
# The GLX libraries
+ donvidia ${libdir}/libEGL.so ${NV_SOVER} ${GL_ROOT}
donvidia ${libdir}/libGL.so ${NV_SOVER} ${GL_ROOT}
+ donvidia ${libdir}/libGLESv1_CM.so ${NV_SOVER} ${GL_ROOT}
+ donvidia ${libdir}/libnvidia-eglcore.so ${NV_SOVER}
donvidia ${libdir}/libnvidia-glcore.so ${NV_SOVER}
+ donvidia ${libdir}/libnvidia-glsi.so ${NV_SOVER}
+ donvidia ${libdir}/libnvidia-ifr.so ${NV_SOVER}
if use kernel_FreeBSD; then
- donvidia ${libdir}/libnvidia-tls.so ${NV_SOVER}
${GL_ROOT}
+ donvidia ${libdir}/libnvidia-tls.so ${NV_SOVER}
else
- donvidia ${libdir}/tls/libnvidia-tls.so ${NV_SOVER}
${GL_ROOT}
+ donvidia ${libdir}/tls/libnvidia-tls.so ${NV_SOVER}
fi
# VDPAU
donvidia ${libdir}/libvdpau_nvidia.so ${NV_SOVER}
+
+ # GLES v2 libraries
+ insinto ${GL_ROOT}
+ doexe ${libdir}/libGLESv2.so.${PV}
+ dosym libGLESv2.so.${PV} ${GL_ROOT}/libGLESv2.so.2
+ dosym libGLESv2.so.2 ${GL_ROOT}/libGLESv2.so
fi
# NVIDIA monitoring library
@@ -417,6 +458,7 @@ src_install-libs() {
donvidia ${libdir}/libcuda.so ${NV_SOVER}
donvidia ${libdir}/libnvidia-compiler.so ${NV_SOVER}
donvidia ${libdir}/libOpenCL.so 1.0.0 ${CL_ROOT}
+ donvidia ${libdir}/libnvidia-opencl.so ${NV_SOVER}
fi
}
@@ -458,7 +500,7 @@ pkg_postinst() {
if ! use X; then
elog "You have elected to not install the X.org driver. Along
with"
- elog "this the OpenGL libraries, XvMC, and VDPAU libraries were
not"
+ elog "this the OpenGL libraries and VDPAU libraries were not"
elog "installed. Additionally, once the driver is loaded your
card"
elog "and fan will run at max speed which may not be desirable."
elog "Use the 'nvidia-smi' init script to have your card and
fan"
diff --git a/x11-drivers/nvidia-drivers/nvidia-drivers-361.18-r2.ebuild
b/x11-drivers/nvidia-drivers/nvidia-drivers-361.18-r2.ebuild
index e2759ed..b2f2410 100644
--- a/x11-drivers/nvidia-drivers/nvidia-drivers-361.18-r2.ebuild
+++ b/x11-drivers/nvidia-drivers/nvidia-drivers-361.18-r2.ebuild
@@ -31,23 +31,20 @@ EMULTILIB_PKG="true"
IUSE="acpi +driver gtk2 gtk3 kernel_FreeBSD kernel_linux +kms multilib
pax_kernel static-libs +tools uvm +X"
REQUIRED_USE="
- tools? ( X || ( gtk2 gtk3 ) )
+ tools? ( X )
+ static-libs? ( tools )
"
COMMON="
app-eselect/eselect-opencl
kernel_linux? ( >=sys-libs/glibc-2.6.1 )
tools? (
- >=x11-libs/libvdpau-1.0
dev-libs/atk
dev-libs/glib:2
dev-libs/jansson
- gtk2? ( >=x11-libs/gtk+-2.4:2 )
gtk3? (
- x11-libs/cairo
x11-libs/gtk+:3
)
- media-libs/mesa
x11-libs/cairo
x11-libs/gdk-pixbuf[X]
x11-libs/gtk+:2
@@ -65,7 +62,6 @@ COMMON="
"
DEPEND="
${COMMON}
- app-arch/xz-utils
kernel_linux? ( virtual/linux-sources )
"
RDEPEND="
@@ -369,6 +365,9 @@ src_install() {
NV_USE_BUNDLED_LIBJANSSON=0 \
install
+ use static-libs && \
+ dolib.a
"${S}"/nvidia-settings-${PV}/src/libXNVCtrl/libXNVCtrl.a
+
insinto /usr/share/nvidia/
doins nvidia-application-profiles-${PV}-key-documentation
@@ -376,9 +375,6 @@ src_install() {
newins \
nvidia-application-profiles-${PV}-rc
nvidia-application-profiles-rc
- use static-libs && \
- dolib.a
"${S}"/nvidia-settings-${PV}/src/libXNVCtrl/libXNVCtrl.a
-
insinto /usr/include/NVCtrl
doins "${S}"/nvidia-settings-${PV}/src/libXNVCtrl/*.h