[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH for-4.0] usb: move ehci_create_ich9_with_compani
From: |
Philippe Mathieu-Daudé |
Subject: |
Re: [Qemu-devel] [PATCH for-4.0] usb: move ehci_create_ich9_with_companions to hw/i386 |
Date: |
Sat, 1 Dec 2018 20:00:44 +0100 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.3.0 |
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 <address@hidden>
> ---
> 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) */
>
- Re: [Qemu-devel] [PATCH for-4.0] usb: move ehci_create_ich9_with_companions to hw/i386,
Philippe Mathieu-Daudé <=