Commit 8e0f5a96 authored by Dan Carpenter's avatar Dan Carpenter Committed by Krzysztof Wilczyński

PCI: endpoint: Clean up error handling in vpci_scan_bus()

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: e35f56bb ("PCI: endpoint: Support NTB transfer between RC and EP")
Link: https://lore.kernel.org/linux-pci/68e0f6a4-fd57-45d0-945b-0876f2c8cb86@moroto.mountainSigned-off-by: default avatarDan Carpenter <dan.carpenter@linaro.org>
Signed-off-by: default avatarKrzysztof Wilczyński <kwilczynski@kernel.org>
Reviewed-by: default avatarIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
parent 03377a69
...@@ -1018,8 +1018,10 @@ static int vpci_scan_bus(void *sysdata) ...@@ -1018,8 +1018,10 @@ static int vpci_scan_bus(void *sysdata)
struct epf_ntb *ndev = sysdata; struct epf_ntb *ndev = sysdata;
vpci_bus = pci_scan_bus(ndev->vbus_number, &vpci_ops, sysdata); vpci_bus = pci_scan_bus(ndev->vbus_number, &vpci_ops, sysdata);
if (vpci_bus) if (!vpci_bus) {
pr_err("create pci bus\n"); pr_err("create pci bus failed\n");
return -EINVAL;
}
pci_bus_add_devices(vpci_bus); pci_bus_add_devices(vpci_bus);
...@@ -1338,10 +1340,14 @@ static int epf_ntb_bind(struct pci_epf *epf) ...@@ -1338,10 +1340,14 @@ static int epf_ntb_bind(struct pci_epf *epf)
goto err_bar_alloc; goto err_bar_alloc;
} }
vpci_scan_bus(ntb); ret = vpci_scan_bus(ntb);
if (ret)
goto err_unregister;
return 0; return 0;
err_unregister:
pci_unregister_driver(&vntb_pci_driver);
err_bar_alloc: err_bar_alloc:
epf_ntb_config_spad_bar_free(ntb); epf_ntb_config_spad_bar_free(ntb);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment