diff options
author | Johannes Berg <johannes.berg@intel.com> | 2012-03-07 12:52:17 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-03-08 13:59:48 -0500 |
commit | b0b4619273dd8b9414a4632f8f229e4f2897ff45 (patch) | |
tree | 38c8a6614c17698575bb61aa52dcdbec7b3fe981 | |
parent | e755f882b7e72c48da820acc24196532977cfd07 (diff) |
iwlwifi: transport's tx_agg_disable must be atomic
At least as long as it is called from the reclaim
flow (iwlagn_check_ratid_empty) it must be atomic.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-trans.h | 4 |
1 files changed, 1 insertions, 3 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-trans.h b/drivers/net/wireless/iwlwifi/iwl-trans.h index 609949f0299c..ed6ab449e439 100644 --- a/drivers/net/wireless/iwlwifi/iwl-trans.h +++ b/drivers/net/wireless/iwlwifi/iwl-trans.h | |||
@@ -306,7 +306,7 @@ static inline struct page *rxb_steal_page(struct iwl_rx_cmd_buffer *r) | |||
306 | * ready and a successful ADDBA response has been received. | 306 | * ready and a successful ADDBA response has been received. |
307 | * May sleep | 307 | * May sleep |
308 | * @tx_agg_disable: de-configure a Tx queue to send AMPDUs | 308 | * @tx_agg_disable: de-configure a Tx queue to send AMPDUs |
309 | * May sleep | 309 | * Must be atomic |
310 | * @free: release all the ressource for the transport layer itself such as | 310 | * @free: release all the ressource for the transport layer itself such as |
311 | * irq, tasklet etc... From this point on, the device may not issue | 311 | * irq, tasklet etc... From this point on, the device may not issue |
312 | * any interrupt (incl. RFKILL). | 312 | * any interrupt (incl. RFKILL). |
@@ -497,8 +497,6 @@ static inline int iwl_trans_reclaim(struct iwl_trans *trans, int sta_id, | |||
497 | static inline int iwl_trans_tx_agg_disable(struct iwl_trans *trans, | 497 | static inline int iwl_trans_tx_agg_disable(struct iwl_trans *trans, |
498 | int sta_id, int tid) | 498 | int sta_id, int tid) |
499 | { | 499 | { |
500 | might_sleep(); | ||
501 | |||
502 | if (trans->state != IWL_TRANS_FW_ALIVE) | 500 | if (trans->state != IWL_TRANS_FW_ALIVE) |
503 | IWL_ERR(trans, "%s bad state = %d", __func__, trans->state); | 501 | IWL_ERR(trans, "%s bad state = %d", __func__, trans->state); |
504 | 502 | ||