Hi Paolo, On 30/11/18 22:45, Paolo Bonzini wrote: > This function is only needed when Q35 is in use. Moving it to > the same file that uses it lets you disable the entire USB > subsystem in x86_64-softmmu.mak; of course doing that will > cause -usb to break horribly, but one thing at a time.
Moving this out of hcd-ehci-pci.c is an improvement. I'm mitigated about adding this to pc_q35.c, but for the goal you mentioned, it is enough. (In a previous work I tried to refactor all ich9 under hw/southbridge/, keeping q35 clean of it. I might continue after qconfig merged, if this is worthwhile). > > Signed-off-by: Paolo Bonzini <pbonz...@redhat.com> > --- > hw/i386/pc_q35.c | 55 > ++++++++++++++++++++++++++++++++++++++++++++++++++- > hw/usb/hcd-ehci-pci.c | 53 ------------------------------------------------- > include/hw/usb.h | 2 -- > 3 files changed, 54 insertions(+), 56 deletions(-) > > diff --git a/hw/i386/pc_q35.c b/hw/i386/pc_q35.c > index ce38129..d2c80c9 100644 > --- a/hw/i386/pc_q35.c > +++ b/hw/i386/pc_q35.c > @@ -58,6 +58,59 @@ > /* ICH9 AHCI has 6 ports */ > #define MAX_SATA_PORTS 6 > > +struct ehci_companions { > + const char *name; > + int func; > + int port; > +}; > + > +static const struct ehci_companions ich9_1d[] = { > + { .name = "ich9-usb-uhci1", .func = 0, .port = 0 }, > + { .name = "ich9-usb-uhci2", .func = 1, .port = 2 }, > + { .name = "ich9-usb-uhci3", .func = 2, .port = 4 }, > +}; > + > +static const struct ehci_companions ich9_1a[] = { > + { .name = "ich9-usb-uhci4", .func = 0, .port = 0 }, > + { .name = "ich9-usb-uhci5", .func = 1, .port = 2 }, > + { .name = "ich9-usb-uhci6", .func = 2, .port = 4 }, > +}; > + > +static int ehci_create_ich9_with_companions(PCIBus *bus, int slot) > +{ > + const struct ehci_companions *comp; > + PCIDevice *ehci, *uhci; > + BusState *usbbus; > + const char *name; > + int i; > + > + switch (slot) { > + case 0x1d: > + name = "ich9-usb-ehci1"; > + comp = ich9_1d; > + break; > + case 0x1a: > + name = "ich9-usb-ehci2"; > + comp = ich9_1a; > + break; > + default: > + return -1; > + } > + > + ehci = pci_create_multifunction(bus, PCI_DEVFN(slot, 7), true, name); > + qdev_init_nofail(&ehci->qdev); > + usbbus = QLIST_FIRST(&ehci->qdev.child_bus); > + > + for (i = 0; i < 3; i++) { > + uhci = pci_create_multifunction(bus, PCI_DEVFN(slot, comp[i].func), > + true, comp[i].name); > + qdev_prop_set_string(&uhci->qdev, "masterbus", usbbus->name); > + qdev_prop_set_uint32(&uhci->qdev, "firstport", comp[i].port); > + qdev_init_nofail(&uhci->qdev); > + } > + return 0; > +} > + > /* PC hardware initialisation */ > static void pc_q35_init(MachineState *machine) > { > @@ -257,7 +310,7 @@ static void pc_q35_init(MachineState *machine) > idebus[0] = idebus[1] = NULL; > } > > - if (0 && machine_usb(machine)) { > + if (machine_usb(machine)) { This change shouldn't be unnotified in the commit message. Maybe this deserves a separate commit? Except this, I am OK with your patch. > /* Should we create 6 UHCI according to ich9 spec? */ > ehci_create_ich9_with_companions(host_bus, 0x1d); > } > diff --git a/hw/usb/hcd-ehci-pci.c b/hw/usb/hcd-ehci-pci.c > index 8c0fc53..69abbf7 100644 > --- a/hw/usb/hcd-ehci-pci.c > +++ b/hw/usb/hcd-ehci-pci.c > @@ -230,56 +230,3 @@ static void ehci_pci_register_types(void) > } > > type_init(ehci_pci_register_types) > - > -struct ehci_companions { > - const char *name; > - int func; > - int port; > -}; > - > -static const struct ehci_companions ich9_1d[] = { > - { .name = "ich9-usb-uhci1", .func = 0, .port = 0 }, > - { .name = "ich9-usb-uhci2", .func = 1, .port = 2 }, > - { .name = "ich9-usb-uhci3", .func = 2, .port = 4 }, > -}; > - > -static const struct ehci_companions ich9_1a[] = { > - { .name = "ich9-usb-uhci4", .func = 0, .port = 0 }, > - { .name = "ich9-usb-uhci5", .func = 1, .port = 2 }, > - { .name = "ich9-usb-uhci6", .func = 2, .port = 4 }, > -}; > - > -int ehci_create_ich9_with_companions(PCIBus *bus, int slot) > -{ > - const struct ehci_companions *comp; > - PCIDevice *ehci, *uhci; > - BusState *usbbus; > - const char *name; > - int i; > - > - switch (slot) { > - case 0x1d: > - name = "ich9-usb-ehci1"; > - comp = ich9_1d; > - break; > - case 0x1a: > - name = "ich9-usb-ehci2"; > - comp = ich9_1a; > - break; > - default: > - return -1; > - } > - > - ehci = pci_create_multifunction(bus, PCI_DEVFN(slot, 7), true, name); > - qdev_init_nofail(&ehci->qdev); > - usbbus = QLIST_FIRST(&ehci->qdev.child_bus); > - > - for (i = 0; i < 3; i++) { > - uhci = pci_create_multifunction(bus, PCI_DEVFN(slot, comp[i].func), > - true, comp[i].name); > - qdev_prop_set_string(&uhci->qdev, "masterbus", usbbus->name); > - qdev_prop_set_uint32(&uhci->qdev, "firstport", comp[i].port); > - qdev_init_nofail(&uhci->qdev); > - } > - return 0; > -} > diff --git a/include/hw/usb.h b/include/hw/usb.h > index a5080ad..4961405 100644 > --- a/include/hw/usb.h > +++ b/include/hw/usb.h > @@ -593,8 +593,6 @@ const char *usb_device_get_product_desc(USBDevice *dev); > > const USBDesc *usb_device_get_usb_desc(USBDevice *dev); > > -int ehci_create_ich9_with_companions(PCIBus *bus, int slot); > - > /* quirks.c */ > > /* In bulk endpoints are streaming data sources (iow behave like isoc eps) */ >