[PATCH ath-next v3] wifi: ath11k: Pass the correct value of each TID during a stop AMPDU session
Baochen Qiang
baochen.qiang at oss.qualcomm.com
Mon Mar 23 20:26:48 PDT 2026
On 3/19/2026 2:56 PM, Reshma Immaculate Rajkumar wrote:
> During ongoing traffic, a request to stop an AMPDU session
> for one TID could incorrectly affect other active sessions.
> This can happen because an incorrect TID reference would be
> passed when updating the BA session state, causing the wrong
> session to be stopped. As a result, the affected session would
> be reduced to a minimal BA size, leading to a noticeable
> throughput degradation.
>
> Fix this issue by passing the correct argument from
> ath11k_dp_rx_ampdu_stop() to ath11k_peer_rx_tid_reo_update()
> during a stop AMPDU session. Instead of passing peer->tx_tid, which
> is the base address of the array, corresponding to TID 0; pass
> the value of &peer->rx_tid[params->tid], where the different TID numbers
> are accounted for.
>
> Tested-on: QCN9074 hw1.0 PCI WLAN.HK.2.9.0.1-02146-QCAHKSWPL_SILICONZ-1
>
> Fixes: d5c65159f2895 ("ath11k: driver for Qualcomm IEEE 802.11ax devices")
> Signed-off-by: Reshma Immaculate Rajkumar <reshma.rajkumar at oss.qualcomm.com>
> ---
> v2:
> * Added QTI yearless copyright
> v3:
> * Removed QUIC copyright information
> ---
> drivers/net/wireless/ath/ath11k/dp_rx.c | 15 +++++++--------
> 1 file changed, 7 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/net/wireless/ath/ath11k/dp_rx.c b/drivers/net/wireless/ath/ath11k/dp_rx.c
> index 49d959b2e148..85defe11750d 100644
> --- a/drivers/net/wireless/ath/ath11k/dp_rx.c
> +++ b/drivers/net/wireless/ath/ath11k/dp_rx.c
> @@ -1,7 +1,7 @@
> // SPDX-License-Identifier: BSD-3-Clause-Clear
> /*
> * Copyright (c) 2018-2019 The Linux Foundation. All rights reserved.
> - * Copyright (c) 2021-2025 Qualcomm Innovation Center, Inc. All rights reserved.
> + * Copyright (c) Qualcomm Technologies, Inc. and/or its subsidiaries.
> */
>
> #include <linux/ieee80211.h>
> @@ -1110,9 +1110,8 @@ int ath11k_dp_rx_ampdu_stop(struct ath11k *ar,
> struct ath11k_base *ab = ar->ab;
> struct ath11k_peer *peer;
> struct ath11k_sta *arsta = ath11k_sta_to_arsta(params->sta);
> + struct dp_rx_tid *rx_tid;
> int vdev_id = arsta->arvif->vdev_id;
> - dma_addr_t paddr;
> - bool active;
> int ret;
>
> spin_lock_bh(&ab->base_lock);
> @@ -1124,15 +1123,14 @@ int ath11k_dp_rx_ampdu_stop(struct ath11k *ar,
> return -ENOENT;
> }
>
> - paddr = peer->rx_tid[params->tid].paddr;
> - active = peer->rx_tid[params->tid].active;
> + rx_tid = &peer->rx_tid[params->tid];
>
> - if (!active) {
> + if (!rx_tid->active) {
> spin_unlock_bh(&ab->base_lock);
> return 0;
> }
>
> - ret = ath11k_peer_rx_tid_reo_update(ar, peer, peer->rx_tid, 1, 0, false);
> + ret = ath11k_peer_rx_tid_reo_update(ar, peer, rx_tid, 1, 0, false);
> spin_unlock_bh(&ab->base_lock);
> if (ret) {
> ath11k_warn(ab, "failed to update reo for rx tid %d: %d\n",
> @@ -1141,7 +1139,8 @@ int ath11k_dp_rx_ampdu_stop(struct ath11k *ar,
> }
>
> ret = ath11k_wmi_peer_rx_reorder_queue_setup(ar, vdev_id,
> - params->sta->addr, paddr,
> + params->sta->addr,
> + rx_tid->paddr,
> params->tid, 1, 1);
> if (ret)
> ath11k_warn(ab, "failed to send wmi to delete rx tid %d\n",
>
> base-commit: 7bbb578fc43e7dcb8690cfc98844bd67bc311e8a
Reviewed-by: Baochen Qiang <baochen.qiang at oss.qualcomm.com>
More information about the ath11k
mailing list