wil_addba_rx_request allocates the rx reorder buffer regardless
of use_rx_hw_reordering settings.
Fix this by checking wil->use_rx_hw_reordering before allocating
the reorder buffer.

Signed-off-by: Maya Erez <[email protected]>
---
 drivers/net/wireless/ath/wil6210/rx_reorder.c | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)

diff --git a/drivers/net/wireless/ath/wil6210/rx_reorder.c 
b/drivers/net/wireless/ath/wil6210/rx_reorder.c
index b608aa1..983bd00 100644
--- a/drivers/net/wireless/ath/wil6210/rx_reorder.c
+++ b/drivers/net/wireless/ath/wil6210/rx_reorder.c
@@ -382,11 +382,13 @@ int wil_addba_rx_request(struct wil6210_priv *wil, u8 mid,
        }
 
        /* apply */
-       r = wil_tid_ampdu_rx_alloc(wil, agg_wsize, ssn);
-       spin_lock_bh(&sta->tid_rx_lock);
-       wil_tid_ampdu_rx_free(wil, sta->tid_rx[tid]);
-       sta->tid_rx[tid] = r;
-       spin_unlock_bh(&sta->tid_rx_lock);
+       if (!wil->use_rx_hw_reordering) {
+               r = wil_tid_ampdu_rx_alloc(wil, agg_wsize, ssn);
+               spin_lock_bh(&sta->tid_rx_lock);
+               wil_tid_ampdu_rx_free(wil, sta->tid_rx[tid]);
+               sta->tid_rx[tid] = r;
+               spin_unlock_bh(&sta->tid_rx_lock);
+       }
 
 out:
        return rc;
-- 
1.9.1

Reply via email to