|
Hans de Goede |
3f1f29 |
From fc63639374684dae600d200c133adad75044e587 Mon Sep 17 00:00:00 2001
|
|
Hans de Goede |
3f1f29 |
From: Hans de Goede <hdegoede@redhat.com>
|
|
Hans de Goede |
3f1f29 |
Date: Fri, 24 Jun 2011 11:29:56 +0200
|
|
Hans de Goede |
3f1f29 |
Subject: [PATCH 04/35] usb: Add a register_companion USB bus op.
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
This is a preparation patch for adding support for USB companion controllers.
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
|
|
Hans de Goede |
3f1f29 |
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
|
|
Hans de Goede |
3f1f29 |
---
|
|
Hans de Goede |
3f1f29 |
hw/usb-bus.c | 31 +++++++++++++++++++++++++++++++
|
|
Hans de Goede |
3f1f29 |
hw/usb.h | 5 +++++
|
|
Hans de Goede |
3f1f29 |
2 files changed, 36 insertions(+), 0 deletions(-)
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
diff --git a/hw/usb-bus.c b/hw/usb-bus.c
|
|
Hans de Goede |
3f1f29 |
index e37e8a2..b511bac 100644
|
|
Hans de Goede |
3f1f29 |
--- a/hw/usb-bus.c
|
|
Hans de Goede |
3f1f29 |
+++ b/hw/usb-bus.c
|
|
Hans de Goede |
3f1f29 |
@@ -160,6 +160,37 @@ void usb_register_port(USBBus *bus, USBPort *port, void *opaque, int index,
|
|
Hans de Goede |
3f1f29 |
bus->nfree++;
|
|
Hans de Goede |
3f1f29 |
}
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
+int usb_register_companion(const char *masterbus, USBPort *ports[],
|
|
Hans de Goede |
3f1f29 |
+ uint32_t portcount, uint32_t firstport,
|
|
Hans de Goede |
3f1f29 |
+ void *opaque, USBPortOps *ops, int speedmask)
|
|
Hans de Goede |
3f1f29 |
+{
|
|
Hans de Goede |
3f1f29 |
+ USBBus *bus;
|
|
Hans de Goede |
3f1f29 |
+ int i;
|
|
Hans de Goede |
3f1f29 |
+
|
|
Hans de Goede |
3f1f29 |
+ QTAILQ_FOREACH(bus, &busses, next) {
|
|
Hans de Goede |
3f1f29 |
+ if (strcmp(bus->qbus.name, masterbus) == 0) {
|
|
Hans de Goede |
3f1f29 |
+ break;
|
|
Hans de Goede |
3f1f29 |
+ }
|
|
Hans de Goede |
3f1f29 |
+ }
|
|
Hans de Goede |
3f1f29 |
+
|
|
Hans de Goede |
3f1f29 |
+ if (!bus || !bus->ops->register_companion) {
|
|
Hans de Goede |
3f1f29 |
+ qerror_report(QERR_INVALID_PARAMETER_VALUE, "masterbus",
|
|
Hans de Goede |
3f1f29 |
+ "an USB masterbus");
|
|
Hans de Goede |
3f1f29 |
+ if (bus) {
|
|
Hans de Goede |
3f1f29 |
+ error_printf_unless_qmp(
|
|
Hans de Goede |
3f1f29 |
+ "USB bus '%s' does not allow companion controllers\n",
|
|
Hans de Goede |
3f1f29 |
+ masterbus);
|
|
Hans de Goede |
3f1f29 |
+ }
|
|
Hans de Goede |
3f1f29 |
+ return -1;
|
|
Hans de Goede |
3f1f29 |
+ }
|
|
Hans de Goede |
3f1f29 |
+
|
|
Hans de Goede |
3f1f29 |
+ for (i = 0; i < portcount; i++) {
|
|
Hans de Goede |
3f1f29 |
+ usb_fill_port(ports[i], opaque, i, ops, speedmask);
|
|
Hans de Goede |
3f1f29 |
+ }
|
|
Hans de Goede |
3f1f29 |
+
|
|
Hans de Goede |
3f1f29 |
+ return bus->ops->register_companion(bus, ports, portcount, firstport);
|
|
Hans de Goede |
3f1f29 |
+}
|
|
Hans de Goede |
3f1f29 |
+
|
|
Hans de Goede |
3f1f29 |
void usb_port_location(USBPort *downstream, USBPort *upstream, int portnr)
|
|
Hans de Goede |
3f1f29 |
{
|
|
Hans de Goede |
3f1f29 |
if (upstream) {
|
|
Hans de Goede |
3f1f29 |
diff --git a/hw/usb.h b/hw/usb.h
|
|
Hans de Goede |
3f1f29 |
index 076e2ff..a5f2efa 100644
|
|
Hans de Goede |
3f1f29 |
--- a/hw/usb.h
|
|
Hans de Goede |
3f1f29 |
+++ b/hw/usb.h
|
|
Hans de Goede |
3f1f29 |
@@ -344,6 +344,8 @@ struct USBBus {
|
|
Hans de Goede |
3f1f29 |
};
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
struct USBBusOps {
|
|
Hans de Goede |
3f1f29 |
+ int (*register_companion)(USBBus *bus, USBPort *ports[],
|
|
Hans de Goede |
3f1f29 |
+ uint32_t portcount, uint32_t firstport);
|
|
Hans de Goede |
3f1f29 |
void (*device_destroy)(USBBus *bus, USBDevice *dev);
|
|
Hans de Goede |
3f1f29 |
};
|
|
Hans de Goede |
3f1f29 |
|
|
Hans de Goede |
3f1f29 |
@@ -356,6 +358,9 @@ USBDevice *usb_create_simple(USBBus *bus, const char *name);
|
|
Hans de Goede |
3f1f29 |
USBDevice *usbdevice_create(const char *cmdline);
|
|
Hans de Goede |
3f1f29 |
void usb_register_port(USBBus *bus, USBPort *port, void *opaque, int index,
|
|
Hans de Goede |
3f1f29 |
USBPortOps *ops, int speedmask);
|
|
Hans de Goede |
3f1f29 |
+int usb_register_companion(const char *masterbus, USBPort *ports[],
|
|
Hans de Goede |
3f1f29 |
+ uint32_t portcount, uint32_t firstport,
|
|
Hans de Goede |
3f1f29 |
+ void *opaque, USBPortOps *ops, int speedmask);
|
|
Hans de Goede |
3f1f29 |
void usb_port_location(USBPort *downstream, USBPort *upstream, int portnr);
|
|
Hans de Goede |
3f1f29 |
void usb_unregister_port(USBBus *bus, USBPort *port);
|
|
Hans de Goede |
3f1f29 |
int usb_device_attach(USBDevice *dev);
|
|
Hans de Goede |
3f1f29 |
--
|
|
Hans de Goede |
3f1f29 |
1.7.5.1
|
|
Hans de Goede |
3f1f29 |
|