mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
pci: Add root bus argument to pci_get_bus_devfn()
pci_get_bus_devfn() interprets a full PCI address string to give a PCIBus * and device/function number within that bus. Currently it assumes it is working on an address under the primary PCI root bus. This patch extends it to allow the caller to specify a root bus. This might seem a little odd since the supplied address can (theoretically) include a PCI domain number. However, attempting to use a non-zero domain number there is currently an error, so that shouldn't really cause problems. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
parent
568f0690fd
commit
85c6e4fabb
3 changed files with 7 additions and 6 deletions
|
@ -589,12 +589,13 @@ int pci_parse_devaddr(const char *addr, int *domp, int *busp,
|
|||
return 0;
|
||||
}
|
||||
|
||||
PCIBus *pci_get_bus_devfn(int *devfnp, const char *devaddr)
|
||||
PCIBus *pci_get_bus_devfn(int *devfnp, PCIBus *root, const char *devaddr)
|
||||
{
|
||||
PCIBus *root = pci_find_primary_bus();
|
||||
int dom, bus;
|
||||
unsigned slot;
|
||||
|
||||
assert(!root->parent_dev);
|
||||
|
||||
if (!root) {
|
||||
fprintf(stderr, "No primary PCI bus\n");
|
||||
return NULL;
|
||||
|
@ -1588,7 +1589,7 @@ PCIDevice *pci_nic_init(NICInfo *nd, const char *default_model,
|
|||
if (i < 0)
|
||||
return NULL;
|
||||
|
||||
bus = pci_get_bus_devfn(&devfn, devaddr);
|
||||
bus = pci_get_bus_devfn(&devfn, pci_find_primary_bus(), devaddr);
|
||||
if (!bus) {
|
||||
error_report("Invalid PCI device address %s for device %s",
|
||||
devaddr, pci_nic_names[i]);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue