qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH 6/8] pci: Simpler implementation of primary PCI


From: Michael S. Tsirkin
Subject: Re: [Qemu-devel] [PATCH 6/8] pci: Simpler implementation of primary PCI bus
Date: Thu, 23 May 2013 14:01:57 +0300

On Thu, May 09, 2013 at 10:31:10AM +1000, David Gibson wrote:
> Currently pci_get_primary_bus() searches the list of root buses for one
> with domain 0.  But since host buses are always registered with domain 0,
> this just amounts to finding the only PCI host bus.
> 
> This simplifies the implementation by defining the primary PCI bus to
> be the first one registered, using a global variable to track it.
> 
> Signed-off-by: David Gibson <address@hidden>

This is the only part that I dislike.
How about an explicit API to set the primary bus?
Let machine types set it.

> ---
>  hw/pci/pci.c |   18 +++++++++---------
>  1 file changed, 9 insertions(+), 9 deletions(-)
> 
> diff --git a/hw/pci/pci.c b/hw/pci/pci.c
> index a3c192c..b25a1a1 100644
> --- a/hw/pci/pci.c
> +++ b/hw/pci/pci.c
> @@ -96,6 +96,7 @@ struct PCIHostBus {
>      QLIST_ENTRY(PCIHostBus) next;
>  };
>  static QLIST_HEAD(, PCIHostBus) host_buses;
> +static PCIBus *pci_primary_bus;
>  
>  static const VMStateDescription vmstate_pcibus = {
>      .name = "PCIBUS",
> @@ -241,6 +242,12 @@ static int pcibus_reset(BusState *qbus)
>  static void pci_host_bus_register(int domain, PCIBus *bus)
>  {
>      struct PCIHostBus *host;
> +
> +    /* If this is the first one, assume it's the primary bus */
> +    if (!pci_primary_bus) {
> +        pci_primary_bus = bus;
> +    }
> +
>      host = g_malloc0(sizeof(*host));
>      host->domain = domain;
>      host->bus = bus;
> @@ -249,15 +256,7 @@ static void pci_host_bus_register(int domain, PCIBus 
> *bus)
>  
>  PCIBus *pci_get_primary_bus(void)
>  {
> -    struct PCIHostBus *host;
> -
> -    QLIST_FOREACH(host, &host_buses, next) {
> -        if (host->domain == 0) {
> -            return host->bus;
> -        }
> -    }
> -
> -    return NULL;
> +    return pci_primary_bus;
>  }
>  
>  PCIBus *pci_device_root_bus(const PCIDevice *d)
> @@ -300,6 +299,7 @@ static void pci_bus_init(PCIBus *bus, DeviceState *parent,
>  
>      /* host bridge */
>      QLIST_INIT(&bus->child);
> +
>      pci_host_bus_register(0, bus); /* for now only pci domain 0 is supported 
> */
>  
>      vmstate_register(NULL, -1, &vmstate_pcibus, bus);
> -- 
> 1.7.10.4



reply via email to

[Prev in Thread] Current Thread [Next in Thread]