mt76: mt76x2: move mutex_lock inside mt76x2_set_channel
authorLorenzo Bianconi <lorenzo@kernel.org>
Sat, 11 May 2019 10:17:53 +0000 (12:17 +0200)
committerFelix Fietkau <nbd@nbd.name>
Tue, 25 Jun 2019 10:55:27 +0000 (12:55 +0200)
This is a preliminary patch to run mt76x02_edcca_init atomically

Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt76x2/pci_main.c
drivers/net/wireless/mediatek/mt76/mt76x2/usb_main.c

index e416eee..3a14673 100644 (file)
@@ -54,14 +54,14 @@ mt76x2_set_channel(struct mt76x02_dev *dev, struct cfg80211_chan_def *chandef)
        int ret;
 
        cancel_delayed_work_sync(&dev->cal_work);
+       tasklet_disable(&dev->mt76.pre_tbtt_tasklet);
+       tasklet_disable(&dev->dfs_pd.dfs_tasklet);
 
+       mutex_lock(&dev->mt76.mutex);
        set_bit(MT76_RESET, &dev->mt76.state);
 
        mt76_set_channel(&dev->mt76);
 
-       tasklet_disable(&dev->mt76.pre_tbtt_tasklet);
-       tasklet_disable(&dev->dfs_pd.dfs_tasklet);
-
        mt76x2_mac_stop(dev, true);
        ret = mt76x2_phy_set_channel(dev, chandef);
 
@@ -72,10 +72,12 @@ mt76x2_set_channel(struct mt76x02_dev *dev, struct cfg80211_chan_def *chandef)
        mt76x02_dfs_init_params(dev);
 
        mt76x2_mac_resume(dev);
-       tasklet_enable(&dev->dfs_pd.dfs_tasklet);
-       tasklet_enable(&dev->mt76.pre_tbtt_tasklet);
 
        clear_bit(MT76_RESET, &dev->mt76.state);
+       mutex_unlock(&dev->mt76.mutex);
+
+       tasklet_enable(&dev->dfs_pd.dfs_tasklet);
+       tasklet_enable(&dev->mt76.pre_tbtt_tasklet);
 
        mt76_txq_schedule_all(&dev->mt76);
 
@@ -111,14 +113,14 @@ mt76x2_config(struct ieee80211_hw *hw, u32 changed)
                }
        }
 
+       mutex_unlock(&dev->mt76.mutex);
+
        if (changed & IEEE80211_CONF_CHANGE_CHANNEL) {
                ieee80211_stop_queues(hw);
                ret = mt76x2_set_channel(dev, &hw->conf.chandef);
                ieee80211_wake_queues(hw);
        }
 
-       mutex_unlock(&dev->mt76.mutex);
-
        return ret;
 }
 
index 3351b73..e4dfc3b 100644 (file)
@@ -48,21 +48,23 @@ mt76x2u_set_channel(struct mt76x02_dev *dev,
        int err;
 
        cancel_delayed_work_sync(&dev->cal_work);
+       dev->beacon_ops->pre_tbtt_enable(dev, false);
+
+       mutex_lock(&dev->mt76.mutex);
        set_bit(MT76_RESET, &dev->mt76.state);
 
        mt76_set_channel(&dev->mt76);
 
-       dev->beacon_ops->pre_tbtt_enable(dev, false);
-
        mt76x2_mac_stop(dev, false);
 
        err = mt76x2u_phy_set_channel(dev, chandef);
 
        mt76x2_mac_resume(dev);
 
-       dev->beacon_ops->pre_tbtt_enable(dev, true);
-
        clear_bit(MT76_RESET, &dev->mt76.state);
+       mutex_unlock(&dev->mt76.mutex);
+
+       dev->beacon_ops->pre_tbtt_enable(dev, true);
        mt76_txq_schedule_all(&dev->mt76);
 
        return err;
@@ -84,12 +86,6 @@ mt76x2u_config(struct ieee80211_hw *hw, u32 changed)
                mt76_wr(dev, MT_RX_FILTR_CFG, dev->mt76.rxfilter);
        }
 
-       if (changed & IEEE80211_CONF_CHANGE_CHANNEL) {
-               ieee80211_stop_queues(hw);
-               err = mt76x2u_set_channel(dev, &hw->conf.chandef);
-               ieee80211_wake_queues(hw);
-       }
-
        if (changed & IEEE80211_CONF_CHANGE_POWER) {
                dev->mt76.txpower_conf = hw->conf.power_level * 2;
 
@@ -102,6 +98,12 @@ mt76x2u_config(struct ieee80211_hw *hw, u32 changed)
 
        mutex_unlock(&dev->mt76.mutex);
 
+       if (changed & IEEE80211_CONF_CHANGE_CHANNEL) {
+               ieee80211_stop_queues(hw);
+               err = mt76x2u_set_channel(dev, &hw->conf.chandef);
+               ieee80211_wake_queues(hw);
+       }
+
        return err;
 }