aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorJohannes Berg <johannes.berg@intel.com>2010-01-20 14:21:06 -0500
committerReinette Chatre <reinette.chatre@intel.com>2010-01-29 14:13:34 -0500
commit47e28f41dce90ea4317d35cf23f232c1a6b07adf (patch)
tree8ddc9b6044c994c5c68f1fc348e9b301fd8ccd6e /drivers/net/wireless
parenta7fce6ee8dd693fb2a9d19ddf9ee1fe380893fa1 (diff)
iwlwifi: fix locking in iwl_mac_add_interface
The corresponding iwl_mac_remove_interface only acquires the mutex, leading me to believe that the spinlock is not necessary. However, this doesn't actually acquire the mutex around the vif pointer check and assignment, fix that. Signed-off-by: Johannes Berg <johannes.berg@intel.com> Signed-off-by: Reinette Chatre <reinette.chatre@intel.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r--drivers/net/wireless/iwlwifi/iwl-core.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-core.c b/drivers/net/wireless/iwlwifi/iwl-core.c
index 1cfabd6be0b8..02bf17ecaf54 100644
--- a/drivers/net/wireless/iwlwifi/iwl-core.c
+++ b/drivers/net/wireless/iwlwifi/iwl-core.c
@@ -2631,23 +2631,21 @@ int iwl_mac_add_interface(struct ieee80211_hw *hw,
2631 struct ieee80211_vif *vif) 2631 struct ieee80211_vif *vif)
2632{ 2632{
2633 struct iwl_priv *priv = hw->priv; 2633 struct iwl_priv *priv = hw->priv;
2634 unsigned long flags; 2634 int err = 0;
2635 2635
2636 IWL_DEBUG_MAC80211(priv, "enter: type %d\n", vif->type); 2636 IWL_DEBUG_MAC80211(priv, "enter: type %d\n", vif->type);
2637 2637
2638 mutex_lock(&priv->mutex);
2639
2638 if (priv->vif) { 2640 if (priv->vif) {
2639 IWL_DEBUG_MAC80211(priv, "leave - vif != NULL\n"); 2641 IWL_DEBUG_MAC80211(priv, "leave - vif != NULL\n");
2640 return -EOPNOTSUPP; 2642 err = -EOPNOTSUPP;
2643 goto out;
2641 } 2644 }
2642 2645
2643 spin_lock_irqsave(&priv->lock, flags);
2644 priv->vif = vif; 2646 priv->vif = vif;
2645 priv->iw_mode = vif->type; 2647 priv->iw_mode = vif->type;
2646 2648
2647 spin_unlock_irqrestore(&priv->lock, flags);
2648
2649 mutex_lock(&priv->mutex);
2650
2651 if (vif->addr) { 2649 if (vif->addr) {
2652 IWL_DEBUG_MAC80211(priv, "Set %pM\n", vif->addr); 2650 IWL_DEBUG_MAC80211(priv, "Set %pM\n", vif->addr);
2653 memcpy(priv->mac_addr, vif->addr, ETH_ALEN); 2651 memcpy(priv->mac_addr, vif->addr, ETH_ALEN);
@@ -2657,10 +2655,11 @@ int iwl_mac_add_interface(struct ieee80211_hw *hw,
2657 /* we are not ready, will run again when ready */ 2655 /* we are not ready, will run again when ready */
2658 set_bit(STATUS_MODE_PENDING, &priv->status); 2656 set_bit(STATUS_MODE_PENDING, &priv->status);
2659 2657
2658 out:
2660 mutex_unlock(&priv->mutex); 2659 mutex_unlock(&priv->mutex);
2661 2660
2662 IWL_DEBUG_MAC80211(priv, "leave\n"); 2661 IWL_DEBUG_MAC80211(priv, "leave\n");
2663 return 0; 2662 return err;
2664} 2663}
2665EXPORT_SYMBOL(iwl_mac_add_interface); 2664EXPORT_SYMBOL(iwl_mac_add_interface);
2666 2665