qcacmn: Add support for wmi halphy stats event path

Added event path support for halphy stats.

CRs-Fixed: 3242406
Change-Id: Ic4820f20ad09a027cec3ae11d746d8bcc084872a
Esse commit está contido em:
Nidhi Jain
2022-07-13 10:08:57 +05:30
commit de Madan Koyyalamudi
commit 69b1820753
5 arquivos alterados com 127 adições e 0 exclusões

Ver arquivo

@@ -4660,6 +4660,36 @@ QDF_STATUS
wmi_unified_extract_cp_stats_more_pending(wmi_unified_t wmi_handle,
void *evt_buf, uint32_t *more_flag);
/**
* wmi_unified_extract_halphy_stats_end_of_event() - extract end_of_event flag
* @wmi_handle: wmi handle
* @evt_buf: event buffer
* @end_of_event_flag: end_of_event flag
*
* This function extracts the end_of_event_flag from fixed param
*
* Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
*/
QDF_STATUS
wmi_unified_extract_halphy_stats_end_of_event(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *end_of_event_flag);
/**
* wmi_unified_extract_halphy_stats_event_count() - extract event_count flag
* @wmi_handle: wmi handle
* @evt_buf: event buffer
* @event_count_flag: event count flag
*
* This function extracts the event_count_flag from fixed param
*
* Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
*/
QDF_STATUS
wmi_unified_extract_halphy_stats_event_count(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *event_count_flag);
/**
* wmi_unified_send_vdev_tsf_tstamp_action_cmd() - send vdev tsf action command
* @wmi: wmi handle

Ver arquivo

@@ -5038,6 +5038,7 @@ typedef enum {
wmi_vdev_disconnect_event_id,
wmi_peer_create_conf_event_id,
wmi_pdev_cp_fwstats_eventid,
wmi_pdev_halphy_fwstats_eventid,
wmi_vdev_send_big_data_p2_eventid,
wmi_pdev_get_dpd_status_event_id,
#ifdef WLAN_FEATURE_PKT_CAPTURE_V2

Ver arquivo

@@ -2862,6 +2862,12 @@ QDF_STATUS (*send_halphy_stats_cmd)(wmi_unified_t wmi_handle,
QDF_STATUS (*extract_cp_stats_more_pending)(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *more_flag);
QDF_STATUS (*extract_halphy_stats_end_of_event)(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *end_of_event_flag);
QDF_STATUS (*extract_halphy_stats_event_count)(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *event_count_flag);
#ifdef WLAN_SUPPORT_INFRA_CTRL_PATH_STATS
QDF_STATUS
(*extract_infra_cp_stats)(wmi_unified_t wmi_handle,

Ver arquivo

@@ -3723,6 +3723,34 @@ wmi_unified_extract_cp_stats_more_pending(wmi_unified_t wmi_handle,
return QDF_STATUS_E_FAILURE;
}
QDF_STATUS
wmi_unified_extract_halphy_stats_end_of_event(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *end_of_event_flag)
{
if (wmi_handle->ops->extract_halphy_stats_end_of_event)
return
wmi_handle->ops->extract_halphy_stats_end_of_event(wmi_handle,
evt_buf,
end_of_event_flag);
return QDF_STATUS_E_FAILURE;
}
QDF_STATUS
wmi_unified_extract_halphy_stats_event_count(wmi_unified_t wmi_handle,
void *evt_buf,
uint32_t *event_count_flag)
{
if (wmi_handle->ops->extract_halphy_stats_event_count)
return
wmi_handle->ops->extract_halphy_stats_event_count(wmi_handle,
evt_buf,
event_count_flag);
return QDF_STATUS_E_FAILURE;
}
/**
* wmi_unified_send_vdev_tsf_tstamp_action_cmd() - send vdev tsf action command
* @wmi: wmi handle

Ver arquivo

@@ -5424,6 +5424,62 @@ extract_cp_stats_more_pending_tlv(wmi_unified_t wmi, void *evt_buf,
return QDF_STATUS_SUCCESS;
}
/**
* extract_halphy_stats_end_of_event_tlv - api to extract end_of_event flag
* from event data
* @wmi_handle: wmi handle
* @evt_buf: event buffer
* @end_of_event_flag: buffer to populate end_of_event flag
*
* Return: status of operation
*/
static QDF_STATUS
extract_halphy_stats_end_of_event_tlv(wmi_unified_t wmi, void *evt_buf,
uint32_t *end_of_event_flag)
{
WMI_HALPHY_CTRL_PATH_STATS_EVENTID_param_tlvs *param_buf;
wmi_halphy_ctrl_path_stats_event_fixed_param *ev;
param_buf = (WMI_HALPHY_CTRL_PATH_STATS_EVENTID_param_tlvs *)evt_buf;
if (!param_buf) {
wmi_err_rl("param_buf is NULL");
return QDF_STATUS_E_FAILURE;
}
ev = (wmi_halphy_ctrl_path_stats_event_fixed_param *)
param_buf->fixed_param;
*end_of_event_flag = ev->end_of_event;
return QDF_STATUS_SUCCESS;
}
/**
* extract_halphy_stats_event_count - api to extract event count flag from
* event data
* @wmi_handle: wmi handle
* @evt_buf: event buffer
* @event_count_flag: buffer to populate event_count flag
*
* Return: status of operation
*/
static QDF_STATUS
extract_halphy_stats_event_count_tlv(wmi_unified_t wmi, void *evt_buf,
uint32_t *event_count_flag)
{
WMI_HALPHY_CTRL_PATH_STATS_EVENTID_param_tlvs *param_buf;
wmi_halphy_ctrl_path_stats_event_fixed_param *ev;
param_buf = (WMI_HALPHY_CTRL_PATH_STATS_EVENTID_param_tlvs *)evt_buf;
if (!param_buf) {
wmi_err_rl("param_buf is NULL");
return QDF_STATUS_E_FAILURE;
}
ev = (wmi_halphy_ctrl_path_stats_event_fixed_param *)
param_buf->fixed_param;
*event_count_flag = ev->event_count;
return QDF_STATUS_SUCCESS;
}
/**
* send_nlo_mawc_cmd_tlv() - Send MAWC NLO configuration
* @wmi_handle: wmi handle
@@ -18841,6 +18897,10 @@ struct wmi_ops tlv_ops = {
#endif /* WLAN_SUPPORT_INFRA_CTRL_PATH_STATS */
.extract_cp_stats_more_pending =
extract_cp_stats_more_pending_tlv,
.extract_halphy_stats_end_of_event =
extract_halphy_stats_end_of_event_tlv,
.extract_halphy_stats_event_count =
extract_halphy_stats_event_count_tlv,
.send_vdev_tsf_tstamp_action_cmd = send_vdev_tsf_tstamp_action_cmd_tlv,
.extract_vdev_tsf_report_event = extract_vdev_tsf_report_event_tlv,
.extract_pdev_csa_switch_count_status =
@@ -19322,6 +19382,8 @@ static void populate_tlv_events_id(uint32_t *event_ids)
WMI_PEER_CREATE_CONF_EVENTID;
event_ids[wmi_pdev_cp_fwstats_eventid] =
WMI_CTRL_PATH_STATS_EVENTID;
event_ids[wmi_pdev_halphy_fwstats_eventid] =
WMI_HALPHY_CTRL_PATH_STATS_EVENTID;
event_ids[wmi_vdev_send_big_data_p2_eventid] =
WMI_VDEV_SEND_BIG_DATA_P2_EVENTID;
event_ids[wmi_pdev_get_dpd_status_event_id] =