Преглед изворни кода

qca-wifi: Support for FR53778 8021p pcp-tid mapping

Add necessary support for pcp-tid mapping feature

Change-Id: I64535d71b937d8380d611e7413b118d70c68a3a6
Debasis Das пре 6 година
родитељ
комит
409e55c083
3 измењених фајлова са 134 додато и 0 уклоњено
  1. 23 0
      wmi/inc/wmi_unified_ap_api.h
  2. 40 0
      wmi/src/wmi_unified_ap_api.c
  3. 71 0
      wmi/src/wmi_unified_non_tlv.c

+ 23 - 0
wmi/inc/wmi_unified_ap_api.h

@@ -251,4 +251,27 @@ QDF_STATUS wmi_unified_peer_chan_width_switch_cmd_send(void *wmi_hdl,
  */
 QDF_STATUS wmi_unified_peer_del_all_wds_entries_cmd_send(void *wmi_hdl,
 		struct peer_del_all_wds_entries_params *param);
+
+/**
+ *  wmi_unified_vdev_pcp_tid_map_cmd_send() - WMI set vap pcp
+ *  tid map cmd function
+ *  @param wmi_handle      : handle to WMI.
+ *  @param param    : pointer to hold pcp param
+ *
+ *  @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
+ */
+QDF_STATUS wmi_unified_vdev_pcp_tid_map_cmd_send(void *wmi_hdl,
+					 struct vap_pcp_tid_map_params *param);
+
+
+/**
+ *  wmi_unified_vdev_tidmap_prec_cmd_send() - WMI set vap tidmap precedence
+ *  cmd function
+ *  @param wmi_handle      : handle to WMI.
+ *  @param param    : pointer to hold precedence param
+ *
+ *  @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
+ */
+QDF_STATUS wmi_unified_vdev_tidmap_prec_cmd_send(void *wmi_hdl,
+					struct vap_tidmap_prec_params *param);
 #endif /* _WMI_UNIFIED_AP_API_H_ */

+ 40 - 0
wmi/src/wmi_unified_ap_api.c

@@ -1141,3 +1141,43 @@ QDF_STATUS wmi_unified_peer_del_all_wds_entries_cmd_send(void *wmi_hdl,
 
 	return QDF_STATUS_E_FAILURE;
 }
+
+/**
+ *  wmi_unified_vdev_pcp_tid_map_cmd_send() - WMI set vap pcp
+ *  tid map cmd function
+ *  @param wmi_handle      : handle to WMI.
+ *  @param param    : pointer to hold pcp param
+ *
+ *  @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
+ */
+QDF_STATUS
+wmi_unified_vdev_pcp_tid_map_cmd_send(void *wmi_hdl,
+				      struct vap_pcp_tid_map_params *param)
+{
+	wmi_unified_t wmi = (wmi_unified_t) wmi_hdl;
+
+	if (wmi->ops->send_vdev_pcp_tid_map_cmd)
+		return wmi->ops->send_vdev_pcp_tid_map_cmd(wmi, param);
+
+	return QDF_STATUS_E_FAILURE;
+}
+
+/**
+ *  wmi_unified_vdev_tidmap_prec_cmd_send() - WMI set vap tidmap precedence
+ *  cmd function
+ *  @param wmi_handle      : handle to WMI.
+ *  @param param    : pointer to hold precedence param
+ *
+ *  @return QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
+ */
+QDF_STATUS
+wmi_unified_vdev_tidmap_prec_cmd_send(void *wmi_hdl,
+				       struct vap_tidmap_prec_params *param)
+{
+	wmi_unified_t wmi = (wmi_unified_t) wmi_hdl;
+
+	if (wmi->ops->send_vdev_tidmap_prec_cmd)
+		return wmi->ops->send_vdev_tidmap_prec_cmd(wmi, param);
+
+	return QDF_STATUS_E_FAILURE;
+}

+ 71 - 0
wmi/src/wmi_unified_non_tlv.c

@@ -8948,6 +8948,75 @@ void wmi_non_tlv_pdev_id_conversion_enable(wmi_unified_t wmi_handle)
 	WMI_LOGD("PDEV conversion Not Available");
 }
 
+/**
+ * send_vdev_pcp_tid_map_cmd_non_tlv()-send pcp tid mapping
+ * WDS entries cmd to fw
+ * @wmi_handle: wmi handle
+ * @param: pointer holding pcp-to-tid mapping details
+ *
+ * Return: 0 for success or error code
+ */
+QDF_STATUS send_vdev_pcp_tid_map_cmd_non_tlv(wmi_unified_t wmi_handle,
+				struct vap_pcp_tid_map_params *param)
+{
+	wmi_vdev_set_pcp_tid_map_cmd *cmd;
+	wmi_buf_t buf;
+	int len = sizeof(wmi_vdev_set_pcp_tid_map_cmd);
+	QDF_STATUS retval;
+
+	buf = wmi_buf_alloc(wmi_handle, len);
+	if (!buf) {
+		WMI_LOGE("wmi_buf_alloc failed");
+		return QDF_STATUS_E_NOMEM;
+	}
+
+	/* wmi_buf_alloc returns zeroed command buffer */
+	cmd = (wmi_vdev_set_pcp_tid_map_cmd *)wmi_buf_data(buf);
+	cmd->vdev_id = param->vdev_id;
+	qdf_mem_copy(cmd->pcp_to_tid_map, param->pcp_to_tid_map,
+		     sizeof(cmd->pcp_to_tid_map));
+	retval = wmi_unified_cmd_send(wmi_handle, buf, len,
+				    WMI_VDEV_SET_PCP_TID_MAP_CMDID);
+	if (retval)
+		wmi_buf_free(buf);
+
+	return retval;
+}
+
+/**
+ * send_vdev_tidmap_prec_cmd_non_tlv()-send pcp tid mapping
+ * WDS entries cmd to fw
+ * @wmi_handle: wmi handle
+ * @param: pointer holding tidmap order details
+ *
+ * Return: 0 for success or error code
+ */
+QDF_STATUS send_vdev_tidmap_prec_cmd_non_tlv(wmi_unified_t wmi_handle,
+					struct vap_tidmap_prec_params *param)
+{
+	wmi_vdev_set_precedence_map_cmd *cmd;
+	wmi_buf_t buf;
+	int len = sizeof(wmi_vdev_set_precedence_map_cmd);
+	QDF_STATUS retval;
+
+	buf = wmi_buf_alloc(wmi_handle, len);
+	if (!buf) {
+		WMI_LOGE("wmi_buf_alloc failed");
+		return QDF_STATUS_E_NOMEM;
+	}
+
+	/* wmi_buf_alloc returns zeroed command buffer */
+	cmd = (wmi_vdev_set_precedence_map_cmd *)wmi_buf_data(buf);
+	cmd->vdev_id = param->vdev_id;
+	cmd->map_precedence = param->map_precedence;
+	retval = wmi_unified_cmd_send(wmi_handle, buf, len,
+				    WMI_VDEV_SET_PRECEDENCE_MAP_CMDID);
+	if (retval)
+		wmi_buf_free(buf);
+
+	return retval;
+}
+
 struct wmi_ops non_tlv_ops =  {
 	.send_vdev_create_cmd = send_vdev_create_cmd_non_tlv,
 	.send_vdev_delete_cmd = send_vdev_delete_cmd_non_tlv,
@@ -9212,6 +9281,8 @@ struct wmi_ops non_tlv_ops =  {
 			extract_ctl_failsafe_check_ev_param_non_tlv,
 	.send_peer_del_all_wds_entries_cmd =
 			send_peer_del_all_wds_entries_cmd_non_tlv,
+	.send_vdev_pcp_tid_map_cmd = send_vdev_pcp_tid_map_cmd_non_tlv,
+	.send_vdev_tidmap_prec_cmd = send_vdev_tidmap_prec_cmd_non_tlv,
 };
 
 /**