]> www.infradead.org Git - linux.git/commitdiff
wifi: ath12k: Optimize NAPI budget by adjusting PPDU processing
authorP Praneesh <quic_ppranees@quicinc.com>
Mon, 23 Dec 2024 06:01:28 +0000 (11:31 +0530)
committerJeff Johnson <jeff.johnson@oss.qualcomm.com>
Sun, 26 Jan 2025 18:41:29 +0000 (10:41 -0800)
In the current implementation, when PPDU spans multiple ring descriptors,
leading to inefficient use of the NAPI budget. The budget counter is
decremented for each ring descriptor, causing rapid depletion of the
budget even though the processing of a single PPDU might not be complete.

To address this issue, modify the code to decrement the budget counter
only when the driver receives HAL_MON_END_OF_PPDU as the end reason. This
change ensures that the budget is decremented only once per PPDU,
resulting in more efficient utilization of the NAPI budget and better
handling of monitor destination ring.

Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.3.1-00173-QCAHKSWPL_SILICONZ-1
Tested-on: WCN7850 hw2.0 PCI WLAN.HMT.1.0.c5-00481-QCAHMTSWPL_V1.0_V2.0_SILICONZ-3

Signed-off-by: P Praneesh <quic_ppranees@quicinc.com>
Link: https://patch.msgid.link/20241223060132.3506372-11-quic_ppranees@quicinc.com
Signed-off-by: Jeff Johnson <jeff.johnson@oss.qualcomm.com>
drivers/net/wireless/ath/ath12k/dp_mon.c

index dbf5afd88ad53ffc88899287c148cb43f94d3bd3..a11b39ae3774522487ae4fc556e800d0081f69dc 100644 (file)
@@ -2388,6 +2388,13 @@ int ath12k_dp_mon_srng_process(struct ath12k *ar, int *budget,
                        goto move_next;
                }
 
+               /* Calculate the budget when the ring descriptor with the
+                * HAL_MON_END_OF_PPDU to ensure that one PPDU worth of data is always
+                * reaped. This helps to efficiently utilize the NAPI budget.
+                */
+               if (end_reason == HAL_MON_END_OF_PPDU)
+                       *budget -= 1;
+
                end_offset = u32_get_bits(info0, HAL_MON_DEST_INFO0_END_OFFSET);
                if (likely(end_offset <= DP_RX_BUFFER_SIZE)) {
                        skb_put(skb, end_offset);