Browse Source

qcacmn: Add API to extract params from WMI ready event

WMI ready event provides num_dscp_tid, num_total_peers and other
information that  is used. Add API to extract these params.

Change-Id: I85ffc43f20935d84de133591020468c5e5f102de
CRs-Fixed: 2141667
Kiran Venkatappa 7 năm trước cách đây
mục cha
commit
094c24f5d9
3 tập tin đã thay đổi với 76 bổ sung0 xóa
  1. 21 0
      wmi_unified_api.c
  2. 27 0
      wmi_unified_non_tlv.c
  3. 28 0
      wmi_unified_tlv.c

+ 21 - 0
wmi_unified_api.c

@@ -4717,6 +4717,27 @@ wmi_host_mac_addr *wmi_ready_extract_mac_addr_list(void *wmi_hdl, void *ev,
 	return NULL;
 }
 
+/**
+ * wmi_extract_ready_params() - Extract data from ready event apart from
+ *                     status, macaddr and version.
+ * @wmi_handle: Pointer to WMI handle.
+ * @evt_buf: Pointer to Ready event buffer.
+ * @ev_param: Pointer to host defined struct to copy the data from event.
+ *
+ * Return: QDF_STATUS_SUCCESS on success.
+ */
+QDF_STATUS wmi_extract_ready_event_params(void *wmi_hdl,
+		void *evt_buf, struct wmi_host_ready_ev_param *ev_param)
+{
+	wmi_unified_t wmi_handle = (wmi_unified_t) wmi_hdl;
+
+	if (wmi_handle->ops->extract_ready_event_params)
+		return wmi_handle->ops->extract_ready_event_params(wmi_handle,
+			evt_buf, ev_param);
+
+	return QDF_STATUS_E_FAILURE;
+}
+
 /**
  * wmi_extract_dbglog_data_len() - extract debuglog data length
  * @wmi_handle: wmi handle

+ 27 - 0
wmi_unified_non_tlv.c

@@ -5833,6 +5833,32 @@ static QDF_STATUS ready_extract_mac_addr_non_tlv(wmi_unified_t wmi_hdl,
 	 return QDF_STATUS_SUCCESS;
 }
 
+/**
+ * extract_ready_params_non_tlv() - Extract data from ready event apart from
+ *                     status, macaddr and version.
+ * @wmi_handle: Pointer to WMI handle.
+ * @evt_buf: Pointer to Ready event buffer.
+ * @ev_param: Pointer to host defined struct to copy the data from event.
+ *
+ * Return: QDF_STATUS_SUCCESS on success.
+ */
+static QDF_STATUS extract_ready_event_params_non_tlv(wmi_unified_t wmi_handle,
+		void *evt_buf, struct wmi_host_ready_ev_param *ev_param)
+{
+	wmi_ready_event *ev = (wmi_ready_event *) evt_buf;
+
+	ev_param->num_dscp_table = ev->num_dscp_table;
+	if (ev->agile_capability)
+		ev_param->agile_capability = true;
+	else
+		ev_param->agile_capability = false;
+	/* Following params not present in non-TLV target. Set Defaults */
+	ev_param->num_extra_mac_addr = 0;
+	ev_param->num_total_peer = 0;
+
+	return QDF_STATUS_SUCCESS;
+}
+
 /**
  * extract_dbglog_data_len_non_tlv() - extract debuglog data length
  * @wmi_handle: wmi handle
@@ -8274,6 +8300,7 @@ struct wmi_ops non_tlv_ops =  {
 	.extract_dbglog_data_len = extract_dbglog_data_len_non_tlv,
 	.ready_extract_init_status = ready_extract_init_status_non_tlv,
 	.ready_extract_mac_addr = ready_extract_mac_addr_non_tlv,
+	.extract_ready_event_params = extract_ready_event_params_non_tlv,
 	.extract_wds_addr_event = extract_wds_addr_event_non_tlv,
 	.extract_dcs_interference_type = extract_dcs_interference_type_non_tlv,
 	.extract_dcs_cw_int = extract_dcs_cw_int_non_tlv,

+ 28 - 0
wmi_unified_tlv.c

@@ -16719,6 +16719,33 @@ static wmi_host_mac_addr *ready_extract_mac_addr_list_tlv(wmi_unified_t wmi_hamd
 	return (wmi_host_mac_addr *) param_buf->mac_addr_list;
 }
 
+/**
+ * extract_ready_params_tlv() - Extract data from ready event apart from
+ *                     status, macaddr and version.
+ * @wmi_handle: Pointer to WMI handle.
+ * @evt_buf: Pointer to Ready event buffer.
+ * @ev_param: Pointer to host defined struct to copy the data from event.
+ *
+ * Return: QDF_STATUS_SUCCESS on success.
+ */
+static QDF_STATUS extract_ready_event_params_tlv(wmi_unified_t wmi_handle,
+		void *evt_buf, struct wmi_host_ready_ev_param *ev_param)
+{
+	WMI_READY_EVENTID_param_tlvs *param_buf = NULL;
+	wmi_ready_event_fixed_param *ev = NULL;
+
+	param_buf = (WMI_READY_EVENTID_param_tlvs *) evt_buf;
+	ev = param_buf->fixed_param;
+
+	ev_param->num_dscp_table = ev->num_dscp_table;
+	ev_param->num_extra_mac_addr = ev->num_extra_mac_addr;
+	ev_param->num_total_peer = ev->num_total_peers;
+	/* Agile_cap in ready event is not supported in TLV target */
+	ev_param->agile_capability = false;
+
+	return QDF_STATUS_SUCCESS;
+}
+
 /**
  * extract_dbglog_data_len_tlv() - extract debuglog data length
  * @wmi_handle: wmi handle
@@ -19960,6 +19987,7 @@ struct wmi_ops tlv_ops =  {
 	.ready_extract_init_status = ready_extract_init_status_tlv,
 	.ready_extract_mac_addr = ready_extract_mac_addr_tlv,
 	.ready_extract_mac_addr_list = ready_extract_mac_addr_list_tlv,
+	.extract_ready_event_params = extract_ready_event_params_tlv,
 	.extract_dbglog_data_len = extract_dbglog_data_len_tlv,
 	.extract_vdev_start_resp = extract_vdev_start_resp_tlv,
 	.extract_tbttoffset_update_params =