pci: Fold pci_get_bus_devfn() into its sole caller
The only remaining caller of pci_get_bus_devfn() is pci_nic_init_nofail(), itself an old compatibility function. Fold the two together to avoid re-using the stale interface. While we're there replace the explicit fprintf()s with error_report(). Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Message-Id: <20190513061939.3464-6-david@gibson.dropbear.id.au> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Reviewed-by: Greg Kurz <groug@kaod.org>
This commit is contained in:
parent
91f4c995f2
commit
2ad778b8c2
60
hw/pci/pci.c
60
hw/pci/pci.c
@ -723,37 +723,6 @@ static int pci_parse_devaddr(const char *addr, int *domp, int *busp,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static PCIBus *pci_get_bus_devfn(int *devfnp, PCIBus *root,
|
||||
const char *devaddr)
|
||||
{
|
||||
int dom, bus;
|
||||
unsigned slot;
|
||||
|
||||
if (!root) {
|
||||
fprintf(stderr, "No primary PCI bus\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
assert(!root->parent_dev);
|
||||
|
||||
if (!devaddr) {
|
||||
*devfnp = -1;
|
||||
return pci_find_bus_nr(root, 0);
|
||||
}
|
||||
|
||||
if (pci_parse_devaddr(devaddr, &dom, &bus, &slot, NULL) < 0) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
if (dom != 0) {
|
||||
fprintf(stderr, "No support for non-zero PCI domains\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
*devfnp = PCI_DEVFN(slot, 0);
|
||||
return pci_find_bus_nr(root, bus);
|
||||
}
|
||||
|
||||
static void pci_init_cmask(PCIDevice *dev)
|
||||
{
|
||||
pci_set_word(dev->cmask + PCI_VENDOR_ID, 0xffff);
|
||||
@ -1895,6 +1864,8 @@ PCIDevice *pci_nic_init_nofail(NICInfo *nd, PCIBus *rootbus,
|
||||
DeviceState *dev;
|
||||
int devfn;
|
||||
int i;
|
||||
int dom, busnr;
|
||||
unsigned slot;
|
||||
|
||||
if (nd->model && !strcmp(nd->model, "virtio")) {
|
||||
g_free(nd->model);
|
||||
@ -1928,7 +1899,32 @@ PCIDevice *pci_nic_init_nofail(NICInfo *nd, PCIBus *rootbus,
|
||||
exit(1);
|
||||
}
|
||||
|
||||
bus = pci_get_bus_devfn(&devfn, rootbus, devaddr);
|
||||
if (!rootbus) {
|
||||
error_report("No primary PCI bus");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
assert(!rootbus->parent_dev);
|
||||
|
||||
if (!devaddr) {
|
||||
devfn = -1;
|
||||
busnr = 0;
|
||||
} else {
|
||||
if (pci_parse_devaddr(devaddr, &dom, &busnr, &slot, NULL) < 0) {
|
||||
error_report("Invalid PCI device address %s for device %s",
|
||||
devaddr, nd->model);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
if (dom != 0) {
|
||||
error_report("No support for non-zero PCI domains");
|
||||
exit(1);
|
||||
}
|
||||
|
||||
devfn = PCI_DEVFN(slot, 0);
|
||||
}
|
||||
|
||||
bus = pci_find_bus_nr(rootbus, busnr);
|
||||
if (!bus) {
|
||||
error_report("Invalid PCI device address %s for device %s",
|
||||
devaddr, nd->model);
|
||||
|
Loading…
Reference in New Issue
Block a user