]> xenbits.xensource.com Git - qemu-xen.git/commitdiff
usb/ohci: Set pad to 0 after frame update
authorPaolo Bonzini <pbonzini@redhat.com>
Tue, 23 May 2023 15:58:40 +0000 (17:58 +0200)
committerMichael Tokarev <mjt@tls.msk.ru>
Sun, 28 May 2023 09:02:26 +0000 (12:02 +0300)
When the OHCI controller's framenumber is incremented, HccaPad1 register
should be set to zero (Ref OHCI Spec 4.4)

ReactOS uses hccaPad1 to determine if the OHCI hardware is running,
consequently it fails this check in current qemu master.

Signed-off-by: Ryan Wendland <wendland@live.com.au>
Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1048
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
(cherry picked from commit 6301460ce9f59885e8feb65185bcfb6b128c8eff)
Signed-off-by: Michael Tokarev <mjt@tls.msk.ru>
hw/usb/hcd-ohci.c

index 9d68036d233cb79a4b9e4d1808e267ce589edc6c..c3ab762f5488ea0d369c944bb7b7d3597006765a 100644 (file)
@@ -1210,6 +1210,8 @@ static void ohci_frame_boundary(void *opaque)
     /* Increment frame number and take care of endianness. */
     ohci->frame_number = (ohci->frame_number + 1) & 0xffff;
     hcca.frame = cpu_to_le16(ohci->frame_number);
+    /* When the HC updates frame number, set pad to 0. Ref OHCI Spec 4.4.1*/
+    hcca.pad = 0;
 
     if (ohci->done_count == 0 && !(ohci->intr_status & OHCI_INTR_WD)) {
         if (!ohci->done)