Pete Wyckoff wrote: > i = pci_module_init(&ns558_pci_driver); > if (i == 0) > have_pci_devices = 1; > > /* > * Probe for ISA ports. > */ > > + i = 0; you don't want to lose the error code. what you want to do is something like the attached patch... -- Jeff Garzik | Building 1024 | The chief enemy of creativity is "good" sense MandrakeSoft | -- Picasso
Index: drivers/char/joystick/ns558.c =================================================================== RCS file: /cvsroot/gkernel/linux_2_4/drivers/char/joystick/ns558.c,v retrieving revision 1.1.1.3 diff -u -r1.1.1.3 ns558.c --- drivers/char/joystick/ns558.c 2000/10/22 23:21:03 1.1.1.3 +++ drivers/char/joystick/ns558.c 2000/11/13 23:51:49 @@ -58,7 +58,6 @@ }; static struct ns558 *ns558; -static int have_pci_devices; /* * ns558_isa_probe() tries to find an isa gameport at the @@ -316,9 +315,8 @@ * it is the least-invasive probe. */ - i = pci_module_init(&ns558_pci_driver); - if (i == 0) - have_pci_devices = 1; + i = pci_register_driver(&ns558_pci_driver); + if (i < 0) return i; /* * Probe for ISA ports. @@ -339,7 +337,7 @@ } #endif - return ns558 ? 0 : -ENODEV; + return 0; } void __exit ns558_exit(void) @@ -368,8 +366,7 @@ port = port->next; } - if (have_pci_devices) - pci_unregister_driver(&ns558_pci_driver); + pci_unregister_driver(&ns558_pci_driver); } module_init(ns558_init);