Re: high irqs-off latency caused by USB serial driver

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Aug 22, 2017 at 02:44:20PM -0600, David Mosberger wrote:
> Greg,
> 
> On Tue, Aug 22, 2017 at 2:25 PM, Greg KH <gregkh@xxxxxxxxxxxxxxxxxxx> wrote:
> 
> > USB has always been a big problem with this, the IRQ patch is very long,
> > and messy and complex.
> 
> Yeah.
> 
> > There was an option a while ago to turn USB irqs
> > into threaded irqs, do those work on your platform?  If so, that might
> > help you out here.
> 
> Do you mean this:
> 
>    https://lkml.org/lkml/2008/10/20/465
> 
> or is there something else/newer?

I think there was something newer than that almost-a-decade-old thread,
but I don't remember.  Look at what the RT kernel patch does, it might
be in there if it wasn't merged into the tree already.

> > The usb-serial path should be really "short" overall, compared with the
> > ohci and tty core logic involved.  What USB-serial driver is this that
> > you are using here?
> 
> It's the FTDI driver (via generic).  I did a quick
> back-of-the-envelope calculation
> and it looks like by changing usb/serial/generic.c to move most of the interrupt
> work to softinterrupt would save about 200 usec out of the 746 usec.  Surely
> that'd be an improvement, but moving the entire OHCI path to softirq would be
> a much bigger win.

By moving just part of the work to a "softirq", yes, that might help,
but then you have increased latency to deal with.

What are your requirements that this code path is causing you problems?
Odds are your USB host controller is pretty horrid, any chance to use a
different chip for it?

thanks,

greg k-h
--
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



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux