Page 1 of 1

USB interrupt transfers

Posted: Sat May 20, 2017 6:37 pm
by BrightLight
Hi.

I am working on USB support for my OS. I chose UHCI as the first USB controller I'll write a driver for, and I built a generic USB interface on top of it. But when I think of the main reason I want USB support (which is USB keyboards and mice), I hit a wall. USB HID devices normally use interrupt transfers to keep the CPU idle when possible, which works with the same idea as PS/2 IRQs as I understand it. What I don't understand is how can I receive unrequested data using UHCI or any other USB controller? I understand that when I want to send/receive data, I construct transfer descriptors with appropriate information, but how can I let the device send me information I didn't ask for? How would I execute other transfer descriptors on the same USB host controller while it would seemingly be polling for data the device sent?
One more question: is it possible to use this "streaming" mode of USB HID devices without actually enabling PCI IRQs? I don't have a full AML interpreter, and so the PCI interrupt line field is probably not very reliable on some real hardware.

Thanks in advance.

Re: USB interrupt transfers

Posted: Sat May 20, 2017 6:49 pm
by BenLunt
omarrx024 wrote:Hi.

I am working on USB support for my OS. I chose UHCI as the first USB controller I'll write a driver for, and I built a generic USB interface on top of it. But when I think of the main reason I want USB support (which is USB keyboards and mice), I hit a wall. USB HID devices normally use interrupt transfers to keep the CPU idle when possible, which works with the same idea as PS/2 IRQs as I understand it. What I don't understand is how can I receive unrequested data using UHCI or any other USB controller? I understand that when I want to send/receive data, I construct transfer descriptors with appropriate information, but how can I let the device send me information I didn't ask for? How would I execute other transfer descriptors on the same USB host controller while it would seemingly be polling for data the device sent?
One more question: is it possible to use this "streaming" mode of USB HID devices without actually enabling PCI IRQs? I don't have a full AML interpreter, and so the PCI interrupt line field is probably not very reliable on some real hardware.

Thanks in advance.
One of the device's descriptors, the Interrupt Descriptor, gives an interval value. Your driver is to request a packet, an interrupt packet, once per interval. For example, if this interval is every 500ms, your driver should request the 3-, 4-, or 5-byte packet every 500ms. If you request it too early, say 400ms and the device hasn't updated it yet, you will either receive a NAK or you will receive the same packet as before. If you request it later, say 600ms, you will receive the next packet.

Anyway, read up on interrupt devices, namely mice and keyboards.
Might I (shamelessly) suggest http://www.fysnet.net/the_universal_serial_bus.htm :-)

Another note is that most BIOS and UHCI hardware will emulate a PS/2 keyboard and mouse until you tell it not to. Therefore, you can continue to use a USB mouse and/or keyboard and a PS/2 driver.

Ben

Re: USB interrupt transfers

Posted: Sat May 20, 2017 6:58 pm
by BrightLight
BenLunt wrote:One of the device's descriptors, the Interrupt Descriptor, gives an interval value. Your driver is to request a packet, an interrupt packet, once per interval. For example, if this interval is every 500ms, your driver should request the 3-, 4-, or 5-byte packet every 500ms. If you request it too early, say 400ms and the device hasn't updated it yet, you will either receive a NAK or you will receive the same packet as before. If you request it later, say 600ms, you will receive the next packet.
Thanks for pointing this out for me. It's incredibly stupid of me not to notice the "interval" field of the endpoint descriptor. :oops:
BenLunt wrote:Might I (shamelessly) suggest http://www.fysnet.net/the_universal_serial_bus.htm :-)
I'm sure it would be a great read, but I'm still underage and cannot have a credit card.
BenLunt wrote:Another note is that most BIOS and UHCI hardware will emulate a PS/2 keyboard and mouse until you tell it not to. Therefore, you can continue to use a USB mouse and/or keyboard and a PS/2 driver.
I am aware of this, but natively supporting USB devices has been in my to-do list for too long, and it's time to narrow down the list. :P

Re: USB interrupt transfers

Posted: Sun May 21, 2017 3:13 am
by Korona
omarrx024 wrote:One more question: is it possible to use this "streaming" mode of USB HID devices without actually enabling PCI IRQs? I don't have a full AML interpreter, and so the PCI interrupt line field is probably not very reliable on some real hardware.
As BenLunt pointed out all USB transfers are initiated by the host, so even for interrupt transfers the host is polling the USB device.

In addition to that it is not possible to receive USB transaction IRQs (i.e. those IRQs that are triggered by the interrupt-on-completion bit in the TD) without enabling PCI interrupts (or polling the UHCI status register). As long as you're using the legacy PIC you're​ fine, as the IRQ line register should be reliable. If you're using the APIC, you need a full AML interpreter (or just use ACPICA) and invoke the _PIC and _PRT control methods.