]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: mt76: mt7915: fix mt7915_mac_set_timing()
authorRyder Lee <ryder.lee@mediatek.com>
Sat, 1 Oct 2022 01:42:44 +0000 (09:42 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 31 Dec 2022 12:26:07 +0000 (13:26 +0100)
[ Upstream commit 0c881dc08fd71ca2673f31a64989fbb28eac26f4 ]

Correct mac timiing settings for different hardware generations.
This improves 40-60Mbps performance.

Fixes: 9aac2969fe5f ("mt76: mt7915: update mac timing settings")
Reported-By: Carson Vandegriffe <carson.vandegriffe@candelatech.com>
Tested-by: Chad Monroe <chad.monroe@smartrg.com>
Signed-off-by: Ryder Lee <ryder.lee@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/wireless/mediatek/mt76/mt7915/mac.c

index 49aa5c056063e3e0d04309fdbc51730824b57c67..68e1cf5a104446b7e84182e0b621e627f11e4c41 100644 (file)
@@ -1146,7 +1146,7 @@ void mt7915_mac_set_timing(struct mt7915_phy *phy)
                  FIELD_PREP(MT_TIMEOUT_VAL_CCA, 48);
        u32 ofdm = FIELD_PREP(MT_TIMEOUT_VAL_PLCP, 60) |
                   FIELD_PREP(MT_TIMEOUT_VAL_CCA, 28);
-       int offset;
+       int eifs_ofdm = 360, sifs = 10, offset;
        bool a_band = !(phy->mt76->chandef.chan->band == NL80211_BAND_2GHZ);
 
        if (!test_bit(MT76_STATE_RUNNING, &phy->mt76->state))
@@ -1164,17 +1164,26 @@ void mt7915_mac_set_timing(struct mt7915_phy *phy)
        reg_offset = FIELD_PREP(MT_TIMEOUT_VAL_PLCP, offset) |
                     FIELD_PREP(MT_TIMEOUT_VAL_CCA, offset);
 
+       if (!is_mt7915(&dev->mt76)) {
+               if (!a_band) {
+                       mt76_wr(dev, MT_TMAC_ICR1(phy->band_idx),
+                               FIELD_PREP(MT_IFS_EIFS_CCK, 314));
+                       eifs_ofdm = 78;
+               } else {
+                       eifs_ofdm = 84;
+               }
+       } else if (a_band) {
+               sifs = 16;
+       }
+
        mt76_wr(dev, MT_TMAC_CDTR(phy->band_idx), cck + reg_offset);
        mt76_wr(dev, MT_TMAC_ODTR(phy->band_idx), ofdm + reg_offset);
        mt76_wr(dev, MT_TMAC_ICR0(phy->band_idx),
-               FIELD_PREP(MT_IFS_EIFS_OFDM, a_band ? 84 : 78) |
+               FIELD_PREP(MT_IFS_EIFS_OFDM, eifs_ofdm) |
                FIELD_PREP(MT_IFS_RIFS, 2) |
-               FIELD_PREP(MT_IFS_SIFS, 10) |
+               FIELD_PREP(MT_IFS_SIFS, sifs) |
                FIELD_PREP(MT_IFS_SLOT, phy->slottime));
 
-       mt76_wr(dev, MT_TMAC_ICR1(phy->band_idx),
-               FIELD_PREP(MT_IFS_EIFS_CCK, 314));
-
        if (phy->slottime < 20 || a_band)
                val = MT7915_CFEND_RATE_DEFAULT;
        else