Message ID | 20221219053844.4084486-1-quic_mkenna@quicinc.com |
---|---|
State | New |
Headers | show |
Series | wifi: ath11k: Add tx ack signal support for mgmt packets | expand |
Maharaja Kennadyrajan <quic_mkenna@quicinc.com> writes: > From: Abinaya Kalaiselvan <quic_akalaise@quicinc.com> > > Add support to notify tx ack signal values for mgmt > packets to userspace through NL interface. > > Advertise NL80211_EXT_FEATURE_ACK_SIGNAL_SUPPORT flag > to enable this feature and it will be used for data > packets as well. > > Tested-on: IPQ8074 hw2.0 AHB WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 > > Signed-off-by: Abinaya Kalaiselvan <quic_akalaise@quicinc.com> > Signed-off-by: Maharaja Kennadyrajan <quic_mkenna@quicinc.com> [...] > --- a/drivers/net/wireless/ath/ath11k/wmi.h > +++ b/drivers/net/wireless/ath/ath11k/wmi.h > @@ -2309,6 +2309,7 @@ struct wmi_init_cmd { > } __packed; > > #define WMI_RSRC_CFG_FLAG1_BSS_CHANNEL_INFO_64 BIT(5) > +#define WMI_RSRC_CFG_FLAG1_ACK_RSSI BIT(18) > > struct wmi_resource_config { > u32 tlv_header; > @@ -4541,6 +4542,8 @@ struct wmi_mgmt_tx_compl_event { > u32 desc_id; > u32 status; > u32 pdev_id; > + u32 ppdu_id; > + u32 ack_rssi; > } __packed; Adding these two fields increases the minimum length for WMI_TAG_MGMT_TX_COMPL_EVENT: [WMI_TAG_MGMT_TX_COMPL_EVENT] = { .min_len = sizeof(struct wmi_mgmt_tx_compl_event) }, If we have a firmware version which doesn't include ppdu_id and ack_rssi in WMI_TAG_MGMT_TX_COMPL_EVENT ath11k will drop those events. Not sure what to do. Is it certain that all ath11k firmware versions have ppdu_id and ack_rssi? Or should handle so in ath11k that ppdu_id and ack_rssi can be optional in the event?
On 1/18/2023 12:03 PM, Kalle Valo wrote: > Maharaja Kennadyrajan <quic_mkenna@quicinc.com> writes: > >> From: Abinaya Kalaiselvan <quic_akalaise@quicinc.com> >> >> Add support to notify tx ack signal values for mgmt >> packets to userspace through NL interface. >> >> Advertise NL80211_EXT_FEATURE_ACK_SIGNAL_SUPPORT flag >> to enable this feature and it will be used for data >> packets as well. >> >> Tested-on: IPQ8074 hw2.0 AHB WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 >> >> Signed-off-by: Abinaya Kalaiselvan <quic_akalaise@quicinc.com> >> Signed-off-by: Maharaja Kennadyrajan <quic_mkenna@quicinc.com> > [...] > >> --- a/drivers/net/wireless/ath/ath11k/wmi.h >> +++ b/drivers/net/wireless/ath/ath11k/wmi.h >> @@ -2309,6 +2309,7 @@ struct wmi_init_cmd { >> } __packed; >> >> #define WMI_RSRC_CFG_FLAG1_BSS_CHANNEL_INFO_64 BIT(5) >> +#define WMI_RSRC_CFG_FLAG1_ACK_RSSI BIT(18) >> >> struct wmi_resource_config { >> u32 tlv_header; >> @@ -4541,6 +4542,8 @@ struct wmi_mgmt_tx_compl_event { >> u32 desc_id; >> u32 status; >> u32 pdev_id; >> + u32 ppdu_id; >> + u32 ack_rssi; >> } __packed; > Adding these two fields increases the minimum length for > WMI_TAG_MGMT_TX_COMPL_EVENT: > > [WMI_TAG_MGMT_TX_COMPL_EVENT] > = { .min_len = sizeof(struct wmi_mgmt_tx_compl_event) }, > > If we have a firmware version which doesn't include ppdu_id and ack_rssi > in WMI_TAG_MGMT_TX_COMPL_EVENT ath11k will drop those events. Not sure > what to do. > > Is it certain that all ath11k firmware versions have ppdu_id and > ack_rssi? Or should handle so in ath11k that ppdu_id and ack_rssi can be > optional in the event? [Maha]: All ath11k firmware versions have ppdu_id and ack_rssi. So, there won't be issue with minimum length for this event.
Maharaja Kennadyrajan <quic_mkenna@quicinc.com> wrote: > Add support to notify tx ack signal values for management > packets to userspace through nl80211 interface. > > Advertise NL80211_EXT_FEATURE_ACK_SIGNAL_SUPPORT flag > to enable this feature and it will be used for data > packets as well. > > Tested-on: IPQ8074 hw2.0 AHB WLAN.HK.2.7.0.1-01744-QCAHKSWPL_SILICONZ-1 > > Signed-off-by: Abinaya Kalaiselvan <quic_akalaise@quicinc.com> > Signed-off-by: Maharaja Kennadyrajan <quic_mkenna@quicinc.com> > Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com> Patch applied to ath-next branch of ath.git, thanks. 01c6c9fccbd5 wifi: ath11k: Add tx ack signal support for management packets
diff --git a/drivers/net/wireless/ath/ath11k/hw.c b/drivers/net/wireless/ath/ath11k/hw.c index ab8f0ccacc6b..60ac215e0678 100644 --- a/drivers/net/wireless/ath/ath11k/hw.c +++ b/drivers/net/wireless/ath/ath11k/hw.c @@ -201,6 +201,7 @@ static void ath11k_init_wmi_config_ipq8074(struct ath11k_base *ab, config->twt_ap_pdev_count = ab->num_radios; config->twt_ap_sta_count = 1000; config->flag1 |= WMI_RSRC_CFG_FLAG1_BSS_CHANNEL_INFO_64; + config->flag1 |= WMI_RSRC_CFG_FLAG1_ACK_RSSI; } static int ath11k_hw_mac_id_to_pdev_id_ipq8074(struct ath11k_hw_params *hw, diff --git a/drivers/net/wireless/ath/ath11k/mac.c b/drivers/net/wireless/ath/ath11k/mac.c index b198edba76eb..6b5198da7f4f 100644 --- a/drivers/net/wireless/ath/ath11k/mac.c +++ b/drivers/net/wireless/ath/ath11k/mac.c @@ -9079,6 +9079,11 @@ static int __ath11k_mac_register(struct ath11k *ar) goto err_free_if_combs; } + if (test_bit(WMI_TLV_SERVICE_TX_DATA_MGMT_ACK_RSSI, + ar->ab->wmi_ab.svc_map)) + wiphy_ext_feature_set(ar->hw->wiphy, + NL80211_EXT_FEATURE_ACK_SIGNAL_SUPPORT); + ar->hw->queues = ATH11K_HW_MAX_QUEUES; ar->hw->wiphy->tx_queue_len = ATH11K_QUEUE_LEN; ar->hw->offchannel_tx_hw_queue = ATH11K_HW_MAX_QUEUES - 1; diff --git a/drivers/net/wireless/ath/ath11k/wmi.c b/drivers/net/wireless/ath/ath11k/wmi.c index 2a8a3e3dcff6..0583d467421b 100644 --- a/drivers/net/wireless/ath/ath11k/wmi.c +++ b/drivers/net/wireless/ath/ath11k/wmi.c @@ -5221,8 +5221,8 @@ static int ath11k_pull_mgmt_rx_params_tlv(struct ath11k_base *ab, return 0; } -static int wmi_process_mgmt_tx_comp(struct ath11k *ar, u32 desc_id, - u32 status) +static int wmi_process_mgmt_tx_comp(struct ath11k *ar, + struct wmi_mgmt_tx_compl_event *tx_compl_param) { struct sk_buff *msdu; struct ieee80211_tx_info *info; @@ -5230,24 +5230,29 @@ static int wmi_process_mgmt_tx_comp(struct ath11k *ar, u32 desc_id, int num_mgmt; spin_lock_bh(&ar->txmgmt_idr_lock); - msdu = idr_find(&ar->txmgmt_idr, desc_id); + msdu = idr_find(&ar->txmgmt_idr, tx_compl_param->desc_id); if (!msdu) { ath11k_warn(ar->ab, "received mgmt tx compl for invalid msdu_id: %d\n", - desc_id); + tx_compl_param->desc_id); spin_unlock_bh(&ar->txmgmt_idr_lock); return -ENOENT; } - idr_remove(&ar->txmgmt_idr, desc_id); + idr_remove(&ar->txmgmt_idr, tx_compl_param->desc_id); spin_unlock_bh(&ar->txmgmt_idr_lock); skb_cb = ATH11K_SKB_CB(msdu); dma_unmap_single(ar->ab->dev, skb_cb->paddr, msdu->len, DMA_TO_DEVICE); info = IEEE80211_SKB_CB(msdu); - if ((!(info->flags & IEEE80211_TX_CTL_NO_ACK)) && !status) + if ((!(info->flags & IEEE80211_TX_CTL_NO_ACK)) && + !tx_compl_param->status) { info->flags |= IEEE80211_TX_STAT_ACK; + if (test_bit(WMI_TLV_SERVICE_TX_DATA_MGMT_ACK_RSSI, + ar->ab->wmi_ab.svc_map)) + info->status.ack_signal = tx_compl_param->ack_rssi; + } ieee80211_tx_status_irqsafe(ar->hw, msdu); @@ -5259,7 +5264,7 @@ static int wmi_process_mgmt_tx_comp(struct ath11k *ar, u32 desc_id, ath11k_dbg(ar->ab, ATH11K_DBG_WMI, "wmi mgmt tx comp pending %d desc id %d\n", - num_mgmt, desc_id); + num_mgmt, tx_compl_param->desc_id); if (!num_mgmt) wake_up(&ar->txmgmt_empty_waitq); @@ -5292,6 +5297,7 @@ static int ath11k_pull_mgmt_tx_compl_param_tlv(struct ath11k_base *ab, param->pdev_id = ev->pdev_id; param->desc_id = ev->desc_id; param->status = ev->status; + param->ack_rssi = ev->ack_rssi; kfree(tb); return 0; @@ -7062,13 +7068,12 @@ static void ath11k_mgmt_tx_compl_event(struct ath11k_base *ab, struct sk_buff *s goto exit; } - wmi_process_mgmt_tx_comp(ar, tx_compl_param.desc_id, - tx_compl_param.status); + wmi_process_mgmt_tx_comp(ar, &tx_compl_param); ath11k_dbg(ab, ATH11K_DBG_MGMT, - "mgmt tx compl ev pdev_id %d, desc_id %d, status %d", + "mgmt tx compl ev pdev_id %d, desc_id %d, status %d ack_rssi %d", tx_compl_param.pdev_id, tx_compl_param.desc_id, - tx_compl_param.status); + tx_compl_param.status, tx_compl_param.ack_rssi); exit: rcu_read_unlock(); diff --git a/drivers/net/wireless/ath/ath11k/wmi.h b/drivers/net/wireless/ath/ath11k/wmi.h index 8f2c07d70a4a..31d14e15ebc1 100644 --- a/drivers/net/wireless/ath/ath11k/wmi.h +++ b/drivers/net/wireless/ath/ath11k/wmi.h @@ -2309,6 +2309,7 @@ struct wmi_init_cmd { } __packed; #define WMI_RSRC_CFG_FLAG1_BSS_CHANNEL_INFO_64 BIT(5) +#define WMI_RSRC_CFG_FLAG1_ACK_RSSI BIT(18) struct wmi_resource_config { u32 tlv_header; @@ -4541,6 +4542,8 @@ struct wmi_mgmt_tx_compl_event { u32 desc_id; u32 status; u32 pdev_id; + u32 ppdu_id; + u32 ack_rssi; } __packed; struct wmi_scan_event {