OSDN Git Service

mt76: fix fix ampdu locking
authorMarkus Theil <markus.theil@tu-ilmenau.de>
Wed, 20 Nov 2019 20:05:31 +0000 (21:05 +0100)
committerKalle Valo <kvalo@codeaurora.org>
Thu, 21 Nov 2019 18:38:30 +0000 (20:38 +0200)
The current ampdu locking code does not unlock its mutex in the early
return case. This patch fixes it.

Signed-off-by: Markus Theil <markus.theil@tu-ilmenau.de>
Acked-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/mediatek/mt76/mt7603/main.c
drivers/net/wireless/mediatek/mt76/mt7615/main.c
drivers/net/wireless/mediatek/mt76/mt76x02_util.c

index 281387c..962e282 100644 (file)
@@ -569,6 +569,7 @@ mt7603_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        u16 ssn = params->ssn;
        u8 ba_size = params->buf_size;
        struct mt76_txq *mtxq;
+       int ret = 0;
 
        if (!txq)
                return -EINVAL;
@@ -597,7 +598,8 @@ mt7603_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
                break;
        case IEEE80211_AMPDU_TX_START:
                mtxq->agg_ssn = IEEE80211_SN_TO_SEQ(ssn);
-               return IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               ret = IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               break;
        case IEEE80211_AMPDU_TX_STOP_CONT:
                mtxq->aggr = false;
                mt7603_mac_tx_ba_reset(dev, msta->wcid.idx, tid, -1);
@@ -606,7 +608,7 @@ mt7603_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        }
        mutex_unlock(&dev->mt76.mutex);
 
-       return 0;
+       return ret;
 }
 
 static void
index 240dab9..070b034 100644 (file)
@@ -484,6 +484,7 @@ mt7615_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        u16 tid = params->tid;
        u16 ssn = params->ssn;
        struct mt76_txq *mtxq;
+       int ret = 0;
 
        if (!txq)
                return -EINVAL;
@@ -513,7 +514,8 @@ mt7615_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
                break;
        case IEEE80211_AMPDU_TX_START:
                mtxq->agg_ssn = IEEE80211_SN_TO_SEQ(ssn);
-               return IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               ret = IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               break;
        case IEEE80211_AMPDU_TX_STOP_CONT:
                mtxq->aggr = false;
                mt7615_mcu_set_tx_ba(dev, params, 0);
@@ -522,7 +524,7 @@ mt7615_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        }
        mutex_unlock(&dev->mt76.mutex);
 
-       return 0;
+       return ret;
 }
 
 const struct ieee80211_ops mt7615_ops = {
index bdc8383..0960fc5 100644 (file)
@@ -357,6 +357,7 @@ int mt76x02_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        u16 tid = params->tid;
        u16 ssn = params->ssn;
        struct mt76_txq *mtxq;
+       int ret = 0;
 
        if (!txq)
                return -EINVAL;
@@ -386,7 +387,8 @@ int mt76x02_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
                break;
        case IEEE80211_AMPDU_TX_START:
                mtxq->agg_ssn = IEEE80211_SN_TO_SEQ(ssn);
-               return IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               ret = IEEE80211_AMPDU_TX_START_IMMEDIATE;
+               break;
        case IEEE80211_AMPDU_TX_STOP_CONT:
                mtxq->aggr = false;
                ieee80211_stop_tx_ba_cb_irqsafe(vif, sta->addr, tid);
@@ -394,7 +396,7 @@ int mt76x02_ampdu_action(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
        }
        mutex_unlock(&dev->mt76.mutex);
 
-       return 0;
+       return ret;
 }
 EXPORT_SYMBOL_GPL(mt76x02_ampdu_action);