diff options
| author | Bjørn Mork <[email protected]> | 2012-09-02 22:26:18 +0000 |
|---|---|---|
| committer | David S. Miller <[email protected]> | 2012-09-03 13:49:00 -0400 |
| commit | 85e87870fa18ec9f5df98e2d3b48f3699560a570 (patch) | |
| tree | 4130f26405eb5cd803b5f553faf8b4c8cb5a8548 /include/linux/timerqueue.h | |
| parent | 4c3a5bdae293f75cdf729c6c00124e8489af2276 (diff) | |
net: usbnet: fix softirq storm on suspend
Suspending an open usbnet device results in constant
rescheduling of usbnet_bh.
commit 65841fd5 "usbnet: handle remote wakeup asap"
refactored the usbnet_bh code to allow sharing the
urb allocate and submit code with usbnet_resume. In
this process, a test for, and immediate return on,
ENOLINK from rx_submit was unintentionally dropped.
The rx queue will not grow if rx_submit fails,
making usbnet_bh reschedule itself. This results
in a softirq storm if the error is persistent.
rx_submit translates the usb_submit_urb error
EHOSTUNREACH into ENOLINK, so this is an expected
and persistent error for a suspended device. The
old code tested for this condition and avoided
rescheduling. Putting this test back.
Cc: <[email protected]> # v3.5
Cc: Ming Lei <[email protected]>
Cc: Oliver Neukum <[email protected]>
Signed-off-by: Bjørn Mork <[email protected]>
Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'include/linux/timerqueue.h')
0 files changed, 0 insertions, 0 deletions