Vue la date de modification de ce fichier (Wed Nov 16 11:50:52 2011), il est assez vraisemblable que les informations contenues soient obsolètes !
Tenez-en compte fortement...

Ennui avec le pilote nVidia 1.0-6629

C'est un soucis entre le pilote nvidia, version 1.0-6111, version 1.0-6629 et le noyau 2.6.10...

Si en chargeant le module nvidia, vous avez ce message d'erreur Unknow symbole 'pci_find-class',il faut patcher le noyau linux avec le patch suivant que vous devez télécharger !

 

Positionnez-vous dans le répertoire /usr/src/linux, copiez-le dedans, et patchez de cette manière :
patch -p1 < nvidia-2.6.10.diff

 

Il vous faut ensuite recompiler le kernel et le pilote nVidia...

 

Ce patch devrait largement être suffisant ; néanmoins, sachez qu'il existe une autre possibilité :
celle de patcher le pilote lui-méme - préférez le patch noyau ci-dessus ! -

patchs pour pilote nvidia sur architectures x86 et x86-64

Les deux patches suivants sont à appliquer selon cette méthode :


sh NVIDIA-Linux-x86_64-1.0-6629-pkg0.run --extract-only
cd NVIDIA-Linux-x86_64-1.0-6629-pkg0
patch -p0 < /path/to/NVIDIA_kernel-1.0-6629-1165235.diff
patch -p0 < /path/to/NVIDIA_kernel-1.0-6629-1171869.diff
./nvidia-installer
 

Appliquer les patches de préférence :

pour Architecture x86
sur les versions du pilote nommées pkg0 ou pkg1.
pour Architecture x86-64
sur la version du pilote nommée pkg2.

 

Présentation des patches

Patch NVIDIA_kernel-1.0-6629-1165235.diff

diff -ru usr/src/nv/nv.c usr/src/nv.1165235/nv.c
--- usr/src/nv/nv.c     2004-11-03 22:53:00.000000000 +0100
+++ usr/src/nv.1165235/nv.c     2004-11-25 16:45:04.000000000 +0100
@@ -1604,9 +1604,8 @@
         }
         nv_vm_list_page_count(at->page_table, at->num_pages);
 
-        
-        
-        vma->vm_flags |= (VM_LOCKED | VM_IO);
+        // mark it as IO so that we don'
t dump it on core dump
+        vma->vm_flags |= VM_IO;
     }
 
     
 

À télécharger !

Patch NVIDIA_kernel-1.0-6629-1171869.diff

diff -ru usr/src/nv/nv-linux.h usr/src/nv.1171869/nv-linux.h
--- usr/src/nv/nv-linux.h       2004-11-03 22:53:00.000000000 +0100
+++ usr/src/nv.1171869/nv-linux.h       2004-12-03 11:34:45.000000000 +0100
@@ -480,12 +480,22 @@
 #define NV_PCI_RESOURCE_SIZE(dev, bar)  ((dev)->resource[(bar) - 1].end - (dev)->resource[(bar) - 1].start + 1)
 
 #define NV_PCI_BUS_NUMBER(dev)        (dev)->bus->number
-#define NV_PCI_SLOT_NUMBER(dev)       PCI_SLOT((dev)->devfn)
+#define NV_PCI_DEVFN(dev)             (dev)->devfn
+#define NV_PCI_SLOT_NUMBER(dev)       PCI_SLOT(NV_PCI_DEVFN(dev))
 
 #ifdef NV_PCI_GET_CLASS_PRESENT
 #define NV_PCI_DEV_PUT(dev)                    pci_dev_put(dev)
 #define NV_PCI_GET_DEVICE(vendor,device,from)  pci_get_device(vendor,device,from)
-#define NV_PCI_GET_SLOT(bus,devfn)             pci_get_slot(pci_find_bus(0,bus),devfn)
+#define NV_PCI_GET_SLOT(bus,devfn)                                       \
+   ({                                                                    \
+        struct pci_dev *__dev = NULL;                                    \
+        while ((__dev = pci_get_device(PCI_ANY_ID, PCI_ANY_ID, __dev)))  \
+        {                                                                \
+            if (NV_PCI_BUS_NUMBER(__dev) == bus                          \
+                    && NV_PCI_DEVFN(__dev) == devfn) break;              \
+        }                                                                \
+        __dev;                                                           \
+    })
 #define NV_PCI_GET_CLASS(class,from)           pci_get_class(class,from)
 #else
 #define NV_PCI_DEV_PUT(dev)
diff -ru usr/src/nv/os-interface.c usr/src/nv.1171869/os-interface.c
--- usr/src/nv/os-interface.c   2004-11-03 22:53:00.000000000 +0100
+++ usr/src/nv.1171869/os-interface.c   2004-12-03 11:34:51.000000000 +0100
@@ -866,7 +866,8 @@
 )
 {
     struct pci_dev *dev;
-    dev = NV_PCI_GET_SLOT(bus, PCI_DEVFN(slot, function));
+    unsigned int devfn = PCI_DEVFN(slot, function);
+    dev = NV_PCI_GET_SLOT(bus, devfn);
     if (dev) {
         if (vendor) *vendor = dev->vendor;
         if (device) *device = dev->device;
 

À télécharger !

 


| Page : Linux : nVidia : Faq : Problem : driver : 1.0-6629 : |>>


 

 

^ Haut de page ^