aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/iwlwifi
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2012-03-07 12:52:17 -0500
committerJohn W. Linville <linville@tuxdriver.com>2012-03-08 13:59:48 -0500
commitb0b4619273dd8b9414a4632f8f229e4f2897ff45 (patch)
tree38c8a6614c17698575bb61aa52dcdbec7b3fe981 /drivers/net/wireless/iwlwifi
parente755f882b7e72c48da820acc24196532977cfd07 (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>
Diffstat (limited to 'drivers/net/wireless/iwlwifi')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-trans.h4
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,
497static inline int iwl_trans_tx_agg_disable(struct iwl_trans *trans, 497static 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