iwlegacy: fix channel switch locking
We use priv->mutex to avoid race conditions between chswitch_done() and mac_channel_switch(), when marking channel switch in progress. But chswitch_done() can be called in atomic context from rx_csa() or with mutex already taken from commit_rxon(). To fix remove mutex from chswitch_done() and use atomic bitops for marking channel switch pending. Cc: stable@kernel.org # 2.6.39+ Signed-off-by:Stanislaw Gruszka <sgruszka@redhat.com> Signed-off-by:
John W. Linville <linville@tuxdriver.com>
Showing
- drivers/net/wireless/iwlegacy/iwl-4965.c 3 additions, 6 deletionsdrivers/net/wireless/iwlegacy/iwl-4965.c
- drivers/net/wireless/iwlegacy/iwl-core.c 13 additions, 17 deletionsdrivers/net/wireless/iwlegacy/iwl-core.c
- drivers/net/wireless/iwlegacy/iwl-core.h 1 addition, 1 deletiondrivers/net/wireless/iwlegacy/iwl-core.h
- drivers/net/wireless/iwlegacy/iwl-dev.h 1 addition, 12 deletionsdrivers/net/wireless/iwlegacy/iwl-dev.h
- drivers/net/wireless/iwlegacy/iwl4965-base.c 10 additions, 10 deletionsdrivers/net/wireless/iwlegacy/iwl4965-base.c
Loading
Please register or sign in to comment