qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [Qemu-devel] [PATCH] hw/usb-ohci.c: Implement remote wakeup
@ 2011-06-07 18:50 Peter Maydell
  2011-06-08  8:06 ` Gerd Hoffmann
  0 siblings, 1 reply; 2+ messages in thread
From: Peter Maydell @ 2011-06-07 18:50 UTC (permalink / raw)
  To: qemu-devel; +Cc: Gerd Hoffmann, patches

Implement the wakeup callback in the OHCI USBPortOps, so that when
a downstream device wakes up it correctly causes the OHCI controller
to come out of suspend.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
---
This patch fixes USB keyboard support on (the not-yet-upstream) OMAP3
for me -- without it Linux puts the port and then the OHCI controller
into suspend, and usb-kbd can't get the controller out of reset when
you press a key.

It works for me and I think it's right, but I'm no USB expert and
it could use review from somebody who is.

 hw/usb-ohci.c |   17 +++++++++++++++++
 1 files changed, 17 insertions(+), 0 deletions(-)

diff --git a/hw/usb-ohci.c b/hw/usb-ohci.c
index 8b966f7..347814e 100644
--- a/hw/usb-ohci.c
+++ b/hw/usb-ohci.c
@@ -367,6 +367,22 @@ static void ohci_detach(USBPort *port1)
         ohci_set_interrupt(s, OHCI_INTR_RHSC);
 }
 
+static void ohci_wakeup(USBDevice *dev)
+{
+    USBBus *bus = usb_bus_from_device(dev);
+    OHCIState *s = container_of(bus, OHCIState, bus);
+    int portnum = dev->port->index;
+    OHCIPort *port = &s->rhport[portnum];
+    if (port->ctrl & OHCI_PORT_PSS) {
+        DPRINTF("usb-ohci: port %d: wakeup\n", portnum);
+        port->ctrl |= OHCI_PORT_PSSC;
+        port->ctrl &= ~OHCI_PORT_PSS;
+        if ((s->ctl & OHCI_CTL_HCFS) == OHCI_USB_SUSPEND) {
+            ohci_set_interrupt(s, OHCI_INTR_RD);
+        }
+    }
+}
+
 /* Reset the controller */
 static void ohci_reset(void *opaque)
 {
@@ -1661,6 +1677,7 @@ static CPUWriteMemoryFunc * const ohci_writefn[3]={
 static USBPortOps ohci_port_ops = {
     .attach = ohci_attach,
     .detach = ohci_detach,
+    .wakeup = ohci_wakeup,
     .complete = ohci_async_complete_packet,
 };
 
-- 
1.7.1

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [Qemu-devel] [PATCH] hw/usb-ohci.c: Implement remote wakeup
  2011-06-07 18:50 [Qemu-devel] [PATCH] hw/usb-ohci.c: Implement remote wakeup Peter Maydell
@ 2011-06-08  8:06 ` Gerd Hoffmann
  0 siblings, 0 replies; 2+ messages in thread
From: Gerd Hoffmann @ 2011-06-08  8:06 UTC (permalink / raw)
  To: Peter Maydell; +Cc: qemu-devel, patches

> This patch fixes USB keyboard support on (the not-yet-upstream) OMAP3
> for me -- without it Linux puts the port and then the OHCI controller
> into suspend, and usb-kbd can't get the controller out of reset when
> you press a key.
>
> It works for me and I think it's right, but I'm no USB expert and
> it could use review from somebody who is.

Looks good, queued up.

thanks,
   Gerd

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2011-06-08  8:06 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-06-07 18:50 [Qemu-devel] [PATCH] hw/usb-ohci.c: Implement remote wakeup Peter Maydell
2011-06-08  8:06 ` Gerd Hoffmann

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).