[arch-commits] Commit in nvidia-340xx/repos (10 files)
Tobias Powalowski
tpowa at archlinux.org
Mon Apr 13 08:03:56 UTC 2015
Date: Monday, April 13, 2015 @ 10:03:55
Author: tpowa
Revision: 236350
archrelease: copy trunk to testing-i686, testing-x86_64
Added:
nvidia-340xx/repos/testing-i686/
nvidia-340xx/repos/testing-i686/PKGBUILD
(from rev 236349, nvidia-340xx/trunk/PKGBUILD)
nvidia-340xx/repos/testing-i686/nv-drm.patch
(from rev 236349, nvidia-340xx/trunk/nv-drm.patch)
nvidia-340xx/repos/testing-i686/nvidia-340xx.install
(from rev 236349, nvidia-340xx/trunk/nvidia-340xx.install)
nvidia-340xx/repos/testing-i686/nvidia-4.0.patch
(from rev 236349, nvidia-340xx/trunk/nvidia-4.0.patch)
nvidia-340xx/repos/testing-x86_64/
nvidia-340xx/repos/testing-x86_64/PKGBUILD
(from rev 236349, nvidia-340xx/trunk/PKGBUILD)
nvidia-340xx/repos/testing-x86_64/nv-drm.patch
(from rev 236349, nvidia-340xx/trunk/nv-drm.patch)
nvidia-340xx/repos/testing-x86_64/nvidia-340xx.install
(from rev 236349, nvidia-340xx/trunk/nvidia-340xx.install)
nvidia-340xx/repos/testing-x86_64/nvidia-4.0.patch
(from rev 236349, nvidia-340xx/trunk/nvidia-4.0.patch)
-------------------------------------+
testing-i686/PKGBUILD | 54 ++++++++++++++++++++++++++++++++++
testing-i686/nv-drm.patch | 27 +++++++++++++++++
testing-i686/nvidia-340xx.install | 15 +++++++++
testing-i686/nvidia-4.0.patch | 28 +++++++++++++++++
testing-x86_64/PKGBUILD | 54 ++++++++++++++++++++++++++++++++++
testing-x86_64/nv-drm.patch | 27 +++++++++++++++++
testing-x86_64/nvidia-340xx.install | 15 +++++++++
testing-x86_64/nvidia-4.0.patch | 28 +++++++++++++++++
8 files changed, 248 insertions(+)
Copied: nvidia-340xx/repos/testing-i686/PKGBUILD (from rev 236349, nvidia-340xx/trunk/PKGBUILD)
===================================================================
--- testing-i686/PKGBUILD (rev 0)
+++ testing-i686/PKGBUILD 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,54 @@
+# $Id: PKGBUILD 221857 2014-09-17 20:29:16Z tpowa $
+# Maintainer : Thomas Baechler <thomas at archlinux.org>
+
+pkgname=nvidia-340xx
+pkgver=340.76
+_extramodules=extramodules-4.0-ARCH
+pkgrel=8
+pkgdesc="NVIDIA drivers for linux, 340xx legacy branch"
+arch=('i686' 'x86_64')
+url="http://www.nvidia.com/"
+depends=('linux>=4.0' 'linux<4.1' 'libgl' "nvidia-340xx-utils=${pkgver}")
+makedepends=('linux-headers>=4.0' 'linux-headers<4.1')
+conflicts=('nvidia')
+license=('custom')
+install=${pkgname}.install
+options=(!strip)
+source=("ftp://download.nvidia.com/XFree86/Linux-x86/${pkgver}/NVIDIA-Linux-x86-${pkgver}.run"
+ "ftp://download.nvidia.com/XFree86/Linux-x86_64/${pkgver}/NVIDIA-Linux-x86_64-${pkgver}-no-compat32.run"
+ nv-drm.patch
+ nvidia-4.0.patch)
+md5sums=('8064c0a0998c3e7ee3c98ac1832b8194'
+ '440df290e213280d6e20d4d4be6f8b4c'
+ '79671a27131da619a33eb02ed0c2c031'
+ 'f42bdf589f52d4e6c38baa5bef15eef8')
+
+[[ "$CARCH" = "i686" ]] && _pkg="NVIDIA-Linux-x86-${pkgver}"
+[[ "$CARCH" = "x86_64" ]] && _pkg="NVIDIA-Linux-x86_64-${pkgver}-no-compat32"
+
+prepare() {
+ sh "${_pkg}.run" --extract-only
+ cd "${_pkg}"
+ # patches here
+ patch -p0 -i ../nv-drm.patch
+ patch -p0 -i ../nvidia-4.0.patch
+}
+
+build() {
+ _kernver="$(cat /usr/lib/modules/${_extramodules}/version)"
+ cd "${_pkg}"/kernel
+ make SYSSRC=/usr/lib/modules/"${_kernver}/build" module
+
+ cd uvm
+ make SYSSRC=/usr/lib/modules/"${_kernver}/build" module
+}
+
+package() {
+ install -D -m644 "${srcdir}/${_pkg}/kernel/nvidia.ko" \
+ "${pkgdir}/usr/lib/modules/${_extramodules}/nvidia.ko"
+ install -D -m644 "${srcdir}/${_pkg}/kernel/uvm/nvidia-uvm.ko" \
+ "${pkgdir}/usr/lib/modules/${_extramodules}/nvidia-uvm.ko"
+ gzip "${pkgdir}/usr/lib/modules/${_extramodules}/"*.ko
+ install -d -m755 "${pkgdir}/usr/lib/modprobe.d"
+ echo "blacklist nouveau" >> "${pkgdir}/usr/lib/modprobe.d/nvidia.conf"
+}
Copied: nvidia-340xx/repos/testing-i686/nv-drm.patch (from rev 236349, nvidia-340xx/trunk/nv-drm.patch)
===================================================================
--- testing-i686/nv-drm.patch (rev 0)
+++ testing-i686/nv-drm.patch 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,27 @@
+--- kernel/nv-drm.c~ 2014-09-12 00:33:06.000000000 +0200
++++ kernel/nv-drm.c 2014-10-14 11:35:52.854400737 +0200
+@@ -18,6 +18,11 @@
+
+ #include <drm/drmP.h>
+
++/* 3.18-rc0+ */
++#ifndef drm_gem_object
++#include <drm/drm_gem.h>
++#endif
++
+ extern nv_linux_state_t *nv_linux_devices;
+
+ struct nv_gem_object {
+diff --git a/kernel/nv-drm.c~ b/kernel/nv-drm.c
+index ecc982a..60d7aae 100644
+--- kernel/nv-drm.c~
++++ kernel/nv-drm.c
+@@ -129,6 +129,8 @@ static struct drm_driver nv_drm_driver = {
+ .gem_prime_vmap = nv_gem_prime_vmap,
+ .gem_prime_vunmap = nv_gem_prime_vunmap,
+
++ .set_busid = drm_pci_set_busid,
++
+ .name = "nvidia-drm",
+ .desc = "NVIDIA DRM driver",
+ .date = "20130102",
Copied: nvidia-340xx/repos/testing-i686/nvidia-340xx.install (from rev 236349, nvidia-340xx/trunk/nvidia-340xx.install)
===================================================================
--- testing-i686/nvidia-340xx.install (rev 0)
+++ testing-i686/nvidia-340xx.install 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,15 @@
+post_install() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+ echo 'In order to use nvidia module, reboot the system.'
+}
+
+post_upgrade() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+}
+
+post_remove() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+}
Copied: nvidia-340xx/repos/testing-i686/nvidia-4.0.patch (from rev 236349, nvidia-340xx/trunk/nvidia-4.0.patch)
===================================================================
--- testing-i686/nvidia-4.0.patch (rev 0)
+++ testing-i686/nvidia-4.0.patch 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,28 @@
+--- kernel/nv-pat.c~ 2015-02-22 20:39:43.889075396 -0800
++++ kernel/nv-pat.c 2015-02-22 20:29:33.519735577 -0800
+@@ -35,8 +35,13 @@
+ unsigned long cr0 = read_cr0();
+ write_cr0(((cr0 & (0xdfffffff)) | 0x40000000));
+ wbinvd();
++#if LINUX_VERSION_CODE >= KERNEL_VERSION(4,0,0)
++ *cr4 = __read_cr4();
++ if (*cr4 & 0x80) __write_cr4(*cr4 & ~0x80);
++#else
+ *cr4 = read_cr4();
+ if (*cr4 & 0x80) write_cr4(*cr4 & ~0x80);
++#endif
+ __flush_tlb();
+ }
+
+@@ -46,7 +46,11 @@
+ wbinvd();
+ __flush_tlb();
+ write_cr0((cr0 & 0x9fffffff));
++#if LINUX_VERSION_CODE >= KERNEL_VERSION(4,0,0)
++ if (cr4 & 0x80) __write_cr4(cr4);
++#else
+ if (cr4 & 0x80) write_cr4(cr4);
++#endif
+ }
+
+ static int nv_determine_pat_mode(void)
Copied: nvidia-340xx/repos/testing-x86_64/PKGBUILD (from rev 236349, nvidia-340xx/trunk/PKGBUILD)
===================================================================
--- testing-x86_64/PKGBUILD (rev 0)
+++ testing-x86_64/PKGBUILD 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,54 @@
+# $Id: PKGBUILD 221857 2014-09-17 20:29:16Z tpowa $
+# Maintainer : Thomas Baechler <thomas at archlinux.org>
+
+pkgname=nvidia-340xx
+pkgver=340.76
+_extramodules=extramodules-4.0-ARCH
+pkgrel=8
+pkgdesc="NVIDIA drivers for linux, 340xx legacy branch"
+arch=('i686' 'x86_64')
+url="http://www.nvidia.com/"
+depends=('linux>=4.0' 'linux<4.1' 'libgl' "nvidia-340xx-utils=${pkgver}")
+makedepends=('linux-headers>=4.0' 'linux-headers<4.1')
+conflicts=('nvidia')
+license=('custom')
+install=${pkgname}.install
+options=(!strip)
+source=("ftp://download.nvidia.com/XFree86/Linux-x86/${pkgver}/NVIDIA-Linux-x86-${pkgver}.run"
+ "ftp://download.nvidia.com/XFree86/Linux-x86_64/${pkgver}/NVIDIA-Linux-x86_64-${pkgver}-no-compat32.run"
+ nv-drm.patch
+ nvidia-4.0.patch)
+md5sums=('8064c0a0998c3e7ee3c98ac1832b8194'
+ '440df290e213280d6e20d4d4be6f8b4c'
+ '79671a27131da619a33eb02ed0c2c031'
+ 'f42bdf589f52d4e6c38baa5bef15eef8')
+
+[[ "$CARCH" = "i686" ]] && _pkg="NVIDIA-Linux-x86-${pkgver}"
+[[ "$CARCH" = "x86_64" ]] && _pkg="NVIDIA-Linux-x86_64-${pkgver}-no-compat32"
+
+prepare() {
+ sh "${_pkg}.run" --extract-only
+ cd "${_pkg}"
+ # patches here
+ patch -p0 -i ../nv-drm.patch
+ patch -p0 -i ../nvidia-4.0.patch
+}
+
+build() {
+ _kernver="$(cat /usr/lib/modules/${_extramodules}/version)"
+ cd "${_pkg}"/kernel
+ make SYSSRC=/usr/lib/modules/"${_kernver}/build" module
+
+ cd uvm
+ make SYSSRC=/usr/lib/modules/"${_kernver}/build" module
+}
+
+package() {
+ install -D -m644 "${srcdir}/${_pkg}/kernel/nvidia.ko" \
+ "${pkgdir}/usr/lib/modules/${_extramodules}/nvidia.ko"
+ install -D -m644 "${srcdir}/${_pkg}/kernel/uvm/nvidia-uvm.ko" \
+ "${pkgdir}/usr/lib/modules/${_extramodules}/nvidia-uvm.ko"
+ gzip "${pkgdir}/usr/lib/modules/${_extramodules}/"*.ko
+ install -d -m755 "${pkgdir}/usr/lib/modprobe.d"
+ echo "blacklist nouveau" >> "${pkgdir}/usr/lib/modprobe.d/nvidia.conf"
+}
Copied: nvidia-340xx/repos/testing-x86_64/nv-drm.patch (from rev 236349, nvidia-340xx/trunk/nv-drm.patch)
===================================================================
--- testing-x86_64/nv-drm.patch (rev 0)
+++ testing-x86_64/nv-drm.patch 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,27 @@
+--- kernel/nv-drm.c~ 2014-09-12 00:33:06.000000000 +0200
++++ kernel/nv-drm.c 2014-10-14 11:35:52.854400737 +0200
+@@ -18,6 +18,11 @@
+
+ #include <drm/drmP.h>
+
++/* 3.18-rc0+ */
++#ifndef drm_gem_object
++#include <drm/drm_gem.h>
++#endif
++
+ extern nv_linux_state_t *nv_linux_devices;
+
+ struct nv_gem_object {
+diff --git a/kernel/nv-drm.c~ b/kernel/nv-drm.c
+index ecc982a..60d7aae 100644
+--- kernel/nv-drm.c~
++++ kernel/nv-drm.c
+@@ -129,6 +129,8 @@ static struct drm_driver nv_drm_driver = {
+ .gem_prime_vmap = nv_gem_prime_vmap,
+ .gem_prime_vunmap = nv_gem_prime_vunmap,
+
++ .set_busid = drm_pci_set_busid,
++
+ .name = "nvidia-drm",
+ .desc = "NVIDIA DRM driver",
+ .date = "20130102",
Copied: nvidia-340xx/repos/testing-x86_64/nvidia-340xx.install (from rev 236349, nvidia-340xx/trunk/nvidia-340xx.install)
===================================================================
--- testing-x86_64/nvidia-340xx.install (rev 0)
+++ testing-x86_64/nvidia-340xx.install 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,15 @@
+post_install() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+ echo 'In order to use nvidia module, reboot the system.'
+}
+
+post_upgrade() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+}
+
+post_remove() {
+ EXTRAMODULES='extramodules-4.0-ARCH'
+ depmod $(cat /usr/lib/modules/$EXTRAMODULES/version)
+}
Copied: nvidia-340xx/repos/testing-x86_64/nvidia-4.0.patch (from rev 236349, nvidia-340xx/trunk/nvidia-4.0.patch)
===================================================================
--- testing-x86_64/nvidia-4.0.patch (rev 0)
+++ testing-x86_64/nvidia-4.0.patch 2015-04-13 08:03:55 UTC (rev 236350)
@@ -0,0 +1,28 @@
+--- kernel/nv-pat.c~ 2015-02-22 20:39:43.889075396 -0800
++++ kernel/nv-pat.c 2015-02-22 20:29:33.519735577 -0800
+@@ -35,8 +35,13 @@
+ unsigned long cr0 = read_cr0();
+ write_cr0(((cr0 & (0xdfffffff)) | 0x40000000));
+ wbinvd();
++#if LINUX_VERSION_CODE >= KERNEL_VERSION(4,0,0)
++ *cr4 = __read_cr4();
++ if (*cr4 & 0x80) __write_cr4(*cr4 & ~0x80);
++#else
+ *cr4 = read_cr4();
+ if (*cr4 & 0x80) write_cr4(*cr4 & ~0x80);
++#endif
+ __flush_tlb();
+ }
+
+@@ -46,7 +46,11 @@
+ wbinvd();
+ __flush_tlb();
+ write_cr0((cr0 & 0x9fffffff));
++#if LINUX_VERSION_CODE >= KERNEL_VERSION(4,0,0)
++ if (cr4 & 0x80) __write_cr4(cr4);
++#else
+ if (cr4 & 0x80) write_cr4(cr4);
++#endif
+ }
+
+ static int nv_determine_pat_mode(void)
More information about the arch-commits
mailing list