On 03/03/2011 01:51 PM, Mark Lord wrote:
On 11-03-03 02:39 PM, Mark Lord wrote:
On 11-03-03 02:06 PM, Alan Stern wrote:
On Thu, 3 Mar 2011, Mark Lord wrote:
Mmm.. I missed that part. Very curious, that.
I wonder if it could be some issue with how the interrupt controller is set up.
Oh the other hand, this USB-GPS is probably a "full-speed" (slow) device,
using the UHCI interface rather than EHCI.
The uhci_irq() handler (in uhci-hcd.c) appears to always return IRQ_HANDLED,
even when it didn't actually handle an IRQ. If I'm reading the code correctly,
then that's a bug, and could cause this issue given the "right" peripheral
(eg. your USB-GPS).
I wonder if uhci_irq() can be a bit more clever and only set IRQ_HANDLED
for interrupts that it actually had to handle? Or am I reading it wrong?
Evidently you didn't see these lines near the start of the routine:
status = inw(uhci->io_addr + USBSTS);
if (!(status& ~USBSTS_HCH)) /* shared interrupt, not mine */
return IRQ_NONE;
No, I saw those. But I don't blindly trust comments. :)
To me, those lines say, "if nothing is active on our bus, then return IRQ_NONE".
With the USB-GPS, the bus probably always as "something active",
even if no URBs have been received at that instant in time.
But I don't have the UHCI spec handy to check right now.
Okay, dug out a UHCI 1.1 spec, and the indication from there
is that uhci_irq() can return IRQ_HANDLED in some cases where IRQ_NONE
is more appropriate.
Also, it is not masking the "Reserved" bits from the status register.
Presumably most implementations "read zero" for those bits,
but perhaps not all do.
Dunno if this is the cause the XT-PIC errors from earlier in this thread though.
I'm pretty sure the kernel always has to run all of the IRQ handlers for
that interrupt even though one of them says "handled" so this wouldn't
cause a lost interrupt. One some devices it's not even possible to tell
for sure whether the device actually generated an interrupt or not, so
the driver has to return IRQ_HANDLED always.
The required behavior is "if you know for sure you did not generate an
interrupt, return IRQ_NONE, otherwise return IRQ_HANDLED".
The only thing falsely returning IRQ_HANDLED really hurts is the
screaming-IRQ detection, since the kernel can't tell that the interrupt
isn't actually being cleared.
--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html