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

Add necessary support for pcp-tid mapping feature

Change-Id: I64535d71b937d8380d611e7413b118d70c68a3a6
This commit is contained in:
Debasis Das
2019-01-29 16:39:21 +05:30
parent dc9ee64e6f
commit 409e55c083
3 changed files with 134 additions and 0 deletions

View File

@@ -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_ */

View File

@@ -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;
}

View File

@@ -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,
};
/**