mt76: mt7603: fix initialization of max rx length
authorFelix Fietkau <nbd@nbd.name>
Fri, 8 Mar 2019 18:50:21 +0000 (19:50 +0100)
committerFelix Fietkau <nbd@nbd.name>
Wed, 1 May 2019 11:03:59 +0000 (13:03 +0200)
The previous version only accidentally disabled A-MSDU deaggregation by
using the wrong mask for rx length configuration, which left previous
length value in place.
Fix the length and initialize the register completely to keep A-MSDU
de-aggregation remaining disabled

Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7603/init.c
drivers/net/wireless/mediatek/mt76/mt7603/regs.h

index d394839..0d347ac 100644 (file)
@@ -167,7 +167,8 @@ mt7603_mac_init(struct mt7603_dev *dev)
                FIELD_PREP(MT_AGG_RETRY_CONTROL_BAR_LIMIT, 1) |
                FIELD_PREP(MT_AGG_RETRY_CONTROL_RTS_LIMIT, 15));
 
-       mt76_rmw(dev, MT_DMA_DCR0, ~0xfffc, 4096);
+       mt76_wr(dev, MT_DMA_DCR0, MT_DMA_DCR0_RX_VEC_DROP |
+               FIELD_PREP(MT_DMA_DCR0_MAX_RX_LEN, 4096));
 
        mt76_rmw(dev, MT_DMA_VCFR0, BIT(0), BIT(13));
        mt76_rmw(dev, MT_DMA_TMCFR0, BIT(0) | BIT(1), BIT(13));
index da6827a..9d257d5 100644 (file)
 #define MT_WF_DMA(ofs)                 (MT_WF_DMA_BASE + (ofs))
 
 #define MT_DMA_DCR0                    MT_WF_DMA(0x000)
+#define MT_DMA_DCR0_MAX_RX_LEN         GENMASK(15, 0)
+#define MT_DMA_DCR0_DAMSDU             BIT(16)
+#define MT_DMA_DCR0_RX_VEC_DROP                BIT(17)
+
 #define MT_DMA_DCR1                    MT_WF_DMA(0x004)
 
 #define MT_DMA_FQCR0                   MT_WF_DMA(0x008)