PCI: endpoint: Clean up error handling in vpci_scan_bus()
authorDan Carpenter <dan.carpenter@linaro.org>
Mon, 10 Jun 2024 09:33:39 +0000 (12:33 +0300)
committerKrzysztof Wilczyński <kwilczynski@kernel.org>
Thu, 4 Jul 2024 14:40:53 +0000 (14:40 +0000)
Smatch complains about inconsistent NULL checking in vpci_scan_bus():

    drivers/pci/endpoint/functions/pci-epf-vntb.c:1024 vpci_scan_bus() error: we previously assumed 'vpci_bus' could be null (see line 1021)

Instead of printing an error message and then crashing we should return
an error code and clean up.

Also the NULL check is reversed so it prints an error for success
instead of failure.

Fixes: e35f56bb0330 ("PCI: endpoint: Support NTB transfer between RC and EP")
Link: https://lore.kernel.org/linux-pci/68e0f6a4-fd57-45d0-945b-0876f2c8cb86@moroto.mountain
Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: Krzysztof Wilczyński <kwilczynski@kernel.org>
Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
drivers/pci/endpoint/functions/pci-epf-vntb.c

index 8e779eecd62d41babe9beca177a01e2fd7ae7f69..7f05a44e9a9fde4c5a4e930dd5fd3f3c7f460d32 100644 (file)
@@ -1018,8 +1018,10 @@ static int vpci_scan_bus(void *sysdata)
        struct epf_ntb *ndev = sysdata;
 
        vpci_bus = pci_scan_bus(ndev->vbus_number, &vpci_ops, sysdata);
-       if (vpci_bus)
-               pr_err("create pci bus\n");
+       if (!vpci_bus) {
+               pr_err("create pci bus failed\n");
+               return -EINVAL;
+       }
 
        pci_bus_add_devices(vpci_bus);
 
@@ -1338,10 +1340,14 @@ static int epf_ntb_bind(struct pci_epf *epf)
                goto err_bar_alloc;
        }
 
-       vpci_scan_bus(ntb);
+       ret = vpci_scan_bus(ntb);
+       if (ret)
+               goto err_unregister;
 
        return 0;
 
+err_unregister:
+       pci_unregister_driver(&vntb_pci_driver);
 err_bar_alloc:
        epf_ntb_config_spad_bar_free(ntb);