]> err.no Git - linux-2.6/commitdiff
iwlwifi: fix potential lock inversion deadlock
authorReinette Chatre <reinette.chatre@intel.com>
Fri, 7 Mar 2008 21:47:20 +0000 (13:47 -0800)
committerJohn W. Linville <linville@tuxdriver.com>
Fri, 7 Mar 2008 22:25:26 +0000 (17:25 -0500)
This is a change to a previous patch ("iwlwifi: 3945 split tx_complete
to command and packet function") to ensure we do not have hardirq safe
locks (priv->lock in this case) depend on hardirq unsafe locks.

We only call iwl3945_tx_queue_reclaim while in a tasklet so we have to use
the irqsafe version of the function.

Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Signed-off-by: Tomas Winkler <tomas.winkler@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/iwlwifi/iwl-3945.c

index dc3d695bf096a2de6a8c5c3b24b64c75c0703ed4..50a641c0c5b79607017e1db4e365b2cc067f06e9 100644 (file)
@@ -283,8 +283,8 @@ static void iwl3945_tx_queue_reclaim(struct iwl3945_priv *priv,
                q->read_ptr = iwl_queue_inc_wrap(q->read_ptr, q->n_bd)) {
 
                tx_info = &txq->txb[txq->q.read_ptr];
-               ieee80211_tx_status(priv->hw, tx_info->skb[0],
-                                   &tx_info->status);
+               ieee80211_tx_status_irqsafe(priv->hw, tx_info->skb[0],
+                                           &tx_info->status);
                tx_info->skb[0] = NULL;
                iwl3945_hw_txq_free_tfd(priv, txq);
        }