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));
 
 #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)