]> www.infradead.org Git - users/willy/linux.git/commitdiff
staging: gpib: cec: Handle gpib_register_driver() errors
authorNihar Chaithanya <niharchaithanya@gmail.com>
Mon, 30 Dec 2024 18:56:25 +0000 (00:26 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 7 Jan 2025 14:38:55 +0000 (15:38 +0100)
The function gpib_register_driver() can fail and result in a
semi-registered module and does not return an error value if it
fails.

Unregister the pci registering function in case gpib_register_driver()
fails and return the error value. Add pr_err() statements indicating the
fail and also the error value.

Signed-off-by: Nihar Chaithanya <niharchaithanya@gmail.com>
Link: https://lore.kernel.org/r/20241230185633.175690-6-niharchaithanya@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/gpib/cec/cec_gpib.c

index 3dc933deb40180bcf4c5b19e021e016283692d5a..e5b0941872f5ca5fc3f6103a3b1a364ac30fb8d7 100644 (file)
@@ -365,11 +365,15 @@ static int __init cec_init_module(void)
 
        result = pci_register_driver(&cec_pci_driver);
        if (result) {
-               pr_err("cec_gpib: pci_driver_register failed!\n");
+               pr_err("cec_gpib: pci_register_driver failed: error = %d\n", result);
                return result;
        }
 
-       gpib_register_driver(&cec_pci_interface, THIS_MODULE);
+       result = gpib_register_driver(&cec_pci_interface, THIS_MODULE);
+       if (result) {
+               pr_err("cec_gpib: gpib_register_driver failed: error = %d\n", result);
+               return result;
+       }
 
        return 0;
 }