diff options
| author | Stanislaw Gruszka <stf_xl@wp.pl> | 2013-07-28 13:17:22 +0200 | 
|---|---|---|
| committer | John W. Linville <linville@tuxdriver.com> | 2013-07-29 14:39:44 -0400 | 
| commit | e2288b66fe7ff0288382b2af671b4da558b44472 (patch) | |
| tree | d26d1e38df570e92077f849ada809d2dfce79c19 /kernel/trace/trace_functions.c | |
| parent | a538ae3189a9fa4095ca58c14bc6593622c89ab9 (diff) | |
rt2x00: fix stop queue
Since we clear QUEUE_STARTED in rt2x00queue_stop_queue(), following
call to rt2x00queue_pause_queue() reduce to noop, i.e we do not
stop queue in mac80211.
To fix that introduce rt2x00queue_pause_queue_nocheck() function,
which will stop queue in mac80211 directly.
Note that rt2x00_start_queue() explicitly set QUEUE_PAUSED bit.
Note also that reordering operations i.e. first call to
rt2x00queue_pause_queue() and then clear QUEUE_STARTED bit, will race
with rt2x00queue_unpause_queue(), so calling ieee80211_stop_queue()
directly is the only available solution to fix the problem without
major rework.
Cc: stable@vger.kernel.org
Signed-off-by: Stanislaw Gruszka <stf_xl@wp.pl>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'kernel/trace/trace_functions.c')
0 files changed, 0 insertions, 0 deletions
