mt76: avoid rx reorder buffer overflow
authorRyder Lee <ryder.lee@mediatek.com>
Fri, 24 Apr 2020 19:32:22 +0000 (03:32 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 22 Jun 2020 07:05:17 +0000 (09:05 +0200)
[ Upstream commit 7c4f744d6703757be959f521a7a441bf34745d99 ]

Enlarge slot to support 11ax 256 BA (256 MPDUs in an AMPDU)

Signed-off-by: Chih-Min Chen <chih-min.chen@mediatek.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/agg-rx.c
drivers/net/wireless/mediatek/mt76/mt76.h

index 73c8b2805c978cb688e73bbd72156078eb98a492..d44d57e6eb27ae643462a4af6e07cde7a19fee32 100644 (file)
@@ -154,8 +154,8 @@ void mt76_rx_aggr_reorder(struct sk_buff *skb, struct sk_buff_head *frames)
        struct ieee80211_sta *sta;
        struct mt76_rx_tid *tid;
        bool sn_less;
-       u16 seqno, head, size;
-       u8 ackp, idx;
+       u16 seqno, head, size, idx;
+       u8 ackp;
 
        __skb_queue_tail(frames, skb);
 
@@ -240,7 +240,7 @@ void mt76_rx_aggr_reorder(struct sk_buff *skb, struct sk_buff_head *frames)
 }
 
 int mt76_rx_aggr_start(struct mt76_dev *dev, struct mt76_wcid *wcid, u8 tidno,
-                      u16 ssn, u8 size)
+                      u16 ssn, u16 size)
 {
        struct mt76_rx_tid *tid;
 
@@ -264,7 +264,7 @@ EXPORT_SYMBOL_GPL(mt76_rx_aggr_start);
 
 static void mt76_rx_aggr_shutdown(struct mt76_dev *dev, struct mt76_rx_tid *tid)
 {
-       u8 size = tid->size;
+       u16 size = tid->size;
        int i;
 
        cancel_delayed_work(&tid->reorder_work);
index 2eab358791633e80e8e0f3c4b10c8d37d0839fa9..7b1667ec619e01786051fbb0608009ebf9da4697 100644 (file)
@@ -193,8 +193,8 @@ struct mt76_rx_tid {
        struct delayed_work reorder_work;
 
        u16 head;
-       u8 size;
-       u8 nframes;
+       u16 size;
+       u16 nframes;
 
        u8 started:1, stopped:1, timer_pending:1;
 
@@ -537,7 +537,7 @@ int mt76_get_survey(struct ieee80211_hw *hw, int idx,
 void mt76_set_stream_caps(struct mt76_dev *dev, bool vht);
 
 int mt76_rx_aggr_start(struct mt76_dev *dev, struct mt76_wcid *wcid, u8 tid,
-                      u16 ssn, u8 size);
+                      u16 ssn, u16 size);
 void mt76_rx_aggr_stop(struct mt76_dev *dev, struct mt76_wcid *wcid, u8 tid);
 
 void mt76_wcid_key_setup(struct mt76_dev *dev, struct mt76_wcid *wcid,