PCIE: check and return bus_register errors
authorRandy Dunlap <rdunlap@xenotime.net>
Sun, 9 Jul 2006 05:58:25 +0000 (22:58 -0700)
committerGreg Kroah-Hartman <gregkh@suse.de>
Wed, 27 Sep 2006 00:43:52 +0000 (17:43 -0700)
Have pcie_port_bus_register() notice and return errors.
Mark it __must_check so that its caller(s) must check its return value.

Signed-off-by: Randy Dunlap <rdunlap@xenotime.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/pci/pcie/portdrv.h
drivers/pci/pcie/portdrv_core.c
drivers/pci/pcie/portdrv_pci.c

index 1d317d22ee892f0dd17efc2b4814c9a9e642a4a1..67fcd176babdb8182242d9d038f5b665364654d6 100644 (file)
@@ -39,7 +39,7 @@ extern int pcie_port_device_suspend(struct pci_dev *dev, pm_message_t state);
 extern int pcie_port_device_resume(struct pci_dev *dev);
 #endif
 extern void pcie_port_device_remove(struct pci_dev *dev);
-extern void pcie_port_bus_register(void);
+extern int pcie_port_bus_register(void);
 extern void pcie_port_bus_unregister(void);
 
 #endif /* _PORTDRV_H_ */
index 55c66226786887e27640285d6167980c2df155aa..cf9e810b4bf818e42357a34e54d0147fb72044bc 100644 (file)
@@ -6,6 +6,7 @@
  * Copyright (C) Tom Long Nguyen (tom.l.nguyen@intel.com)
  */
 
+#include <linux/compiler.h>
 #include <linux/module.h>
 #include <linux/pci.h>
 #include <linux/kernel.h>
@@ -402,9 +403,9 @@ void pcie_port_device_remove(struct pci_dev *dev)
                pci_disable_msi(dev);
 }
 
-void pcie_port_bus_register(void)
+int __must_check pcie_port_bus_register(void)
 {
-       bus_register(&pcie_port_bus_type);
+       return bus_register(&pcie_port_bus_type);
 }
 
 void pcie_port_bus_unregister(void)
index 478d0d28f7ad1e6b573e5e3c3a26f37b9dc1e557..3284199ce3969557126d54ef7e5d5371aded3a8c 100644 (file)
@@ -129,12 +129,17 @@ static struct pci_driver pcie_portdrv = {
 
 static int __init pcie_portdrv_init(void)
 {
-       int retval = 0;
+       int retval;
 
-       pcie_port_bus_register();
+       retval = pcie_port_bus_register();
+       if (retval) {
+               printk(KERN_WARNING "PCIE: bus_register error: %d\n", retval);
+               goto out;
+       }
        retval = pci_register_driver(&pcie_portdrv);
        if (retval)
                pcie_port_bus_unregister();
+ out:
        return retval;
 }