Re: [PATCH] usb: check for signals in chaoskey read function

From: Keith Packard
Date: Tue Feb 16 2016 - 14:10:34 EST


Oliver Neukum <oneukum@xxxxxxxx> writes:

> why is this needed? You are doing this right after a
> mutex_lock_interruptible().

When the device isn't contended, this mutex will never block and so
mutex_lock_interruptible will never check for a signal.

I had mistakenly assumed that usb_bulk_msg would abort when a signal was
delivered, but it doesn't.

I could be convinced that the driver should be using a different path
through the USB stack that would allow a signal to wake up while waiting
for the URB to complete, but this patch at least avoids needing to wait
for a huge read to finish. The other option would be to eliminate the
loop reading multiple URBs from the device, but that would reduce the
available bandwidth from the device pretty considerably.

--
-keith

Attachment: signature.asc
Description: PGP signature