Hi,

Greg Kroah-Hartman <gre...@linuxfoundation.org> writes:
> On Mon, Apr 11, 2016 at 03:44:09PM +0300, Felipe Balbi wrote:
>> Hi guys,
>> 
>> this patchset introduces support for threaded IRQs
>> for host controllers drivers to use. Right now, only
>> XHCI has been converted, but more drivers could
>> easily be converted as well.
>> 
>> With this series we can, eventually, spend much less
>> time with IRQs disabled. Note that, because we're
>> masking XHCI's IRQs, we could run our thread
>> handlers with IRQs enabled, but I haven't tested
>> that yet.
>
> Does it really benifit anything?  Do you have any measurements?  Why the

I have measurements showing that it doesn't have a negative impact.

> added work for no real need, and increased latency?

the latency is negligible. XHCI's irqs are used for completions and
aborts, not to start transfers. Also, it's a generally a good idea to
spend less time in hardirq context. Not to mention that this is a good
stepping stone for further optimization; we could (and probably should)
have a per-device-slot irq thread and also per-device-slot locks and
demote the controller's lock to only the parts which actually need to
access controller-wide resources (for the most part we have
slot-specific registers, anyway).

Now, the benefit of the work yet to come is that we could be processing
N slots concurrently given we have N cpu cores.

Note, also, that we're not forcing anybody to use this but given that
XHCI has these separate units referred to as 'device slots', we might as
well exploit that, right ?

-- 
balbi

Attachment: signature.asc
Description: PGP signature

Reply via email to