diff options
-rw-r--r-- | drivers/net/wireless/ath/ath12k/dp.c | 6 | ||||
-rw-r--r-- | drivers/net/wireless/ath/ath12k/dp_mon.c | 12 |
2 files changed, 17 insertions, 1 deletions
diff --git a/drivers/net/wireless/ath/ath12k/dp.c b/drivers/net/wireless/ath/ath12k/dp.c index 8e4d8ef3229f..5ee879cdf977 100644 --- a/drivers/net/wireless/ath/ath12k/dp.c +++ b/drivers/net/wireless/ath/ath12k/dp.c @@ -933,7 +933,11 @@ int ath12k_dp_service_srng(struct ath12k_base *ab, int id = i * ab->hw_params->num_rxdma_per_pdev + j; if (ring_mask & BIT(id)) { - /* TODO: add monitor mode function */ + work_done = + ath12k_dp_mon_process_ring(ab, id, napi, budget, + 0); + budget -= work_done; + tot_work_done += work_done; if (budget <= 0) goto done; } diff --git a/drivers/net/wireless/ath/ath12k/dp_mon.c b/drivers/net/wireless/ath/ath12k/dp_mon.c index 28fb9d4aa673..0f7d0d517372 100644 --- a/drivers/net/wireless/ath/ath12k/dp_mon.c +++ b/drivers/net/wireless/ath/ath12k/dp_mon.c @@ -3727,6 +3727,14 @@ free_skb: return num_buffs_reaped; } +static int +__ath12k_dp_mon_process_ring(struct ath12k *ar, int mac_id, + struct napi_struct *napi, int *budget) +{ + /* TODO:Implement monitor mode for WCN7850 here. */ + return 0; +} + int ath12k_dp_mon_process_ring(struct ath12k_base *ab, int mac_id, struct napi_struct *napi, int budget, enum dp_monitor_mode monitor_mode) @@ -3737,6 +3745,10 @@ int ath12k_dp_mon_process_ring(struct ath12k_base *ab, int mac_id, if (ab->hw_params->rxdma1_enable) { if (monitor_mode == ATH12K_DP_RX_MONITOR_MODE) num_buffs_reaped = ath12k_dp_mon_srng_process(ar, &budget, napi); + } else { + if (ar->monitor_started) + num_buffs_reaped = + __ath12k_dp_mon_process_ring(ar, mac_id, napi, &budget); } return num_buffs_reaped; |