From f8184296b66293beca5480a9d18927db8ab87aa9 Mon Sep 17 00:00:00 2001 From: Gurumoorthi Gnanasambandhan Date: Tue, 23 Jul 2019 12:10:37 +0530 Subject: [PATCH] qca-wifi: BA window reset after FT roam Reset seq number for Station roaming back in FT roam. Change-Id: I701cf82786ef79bd5fde92ea94957523de807d48 --- wmi/inc/wmi_unified_ap_api.h | 14 ++++++++++++++ wmi/src/wmi_unified_ap_api.c | 11 +++++++++++ wmi/src/wmi_unified_non_tlv.c | 35 +++++++++++++++++++++++++++++++++++ 3 files changed, 60 insertions(+) diff --git a/wmi/inc/wmi_unified_ap_api.h b/wmi/inc/wmi_unified_ap_api.h index 002bd4f634..8dc898dd70 100644 --- a/wmi/inc/wmi_unified_ap_api.h +++ b/wmi/inc/wmi_unified_ap_api.h @@ -132,6 +132,20 @@ QDF_STATUS wmi_unified_peer_update_wds_entry_cmd_send( wmi_unified_t wmi_handle, struct peer_update_wds_entry_params *param); + +/** + * wmi_unified_peer_ft_roam_send() - reset BA window in fw + * @wmi_handle: wmi handle + * @peer_addr: peer mac address + * @vdev_id: vdev id + * + * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure + */ +QDF_STATUS +wmi_unified_peer_ft_roam_send(wmi_unified_t wmi_handle, + uint8_t peer_addr[QDF_MAC_ADDR_SIZE], + uint8_t vdev_id); + /** * wmi_unified_vdev_set_neighbour_rx_cmd_send() - WMI set neighbour rx function * @wmi_handle: handle to WMI. diff --git a/wmi/src/wmi_unified_ap_api.c b/wmi/src/wmi_unified_ap_api.c index 60e119e960..5945a87ee0 100644 --- a/wmi/src/wmi_unified_ap_api.c +++ b/wmi/src/wmi_unified_ap_api.c @@ -400,6 +400,17 @@ QDF_STATUS wmi_extract_vdev_peer_delete_all_response_event( return QDF_STATUS_E_FAILURE; } +QDF_STATUS wmi_unified_peer_ft_roam_send(wmi_unified_t wmi_handle, + uint8_t peer_addr[QDF_MAC_ADDR_SIZE], + uint8_t vdev_id) +{ + if (wmi_handle->ops->send_peer_ft_roam_cmd) + return wmi_handle->ops->send_peer_ft_roam_cmd(wmi_handle, + peer_addr, vdev_id); + + return QDF_STATUS_E_FAILURE; +} + QDF_STATUS wmi_extract_pdev_tpc_ev_param( wmi_unified_t wmi_handle, void *evt_buf, wmi_host_pdev_tpc_event *param) diff --git a/wmi/src/wmi_unified_non_tlv.c b/wmi/src/wmi_unified_non_tlv.c index 5a26492ca7..0871731f58 100644 --- a/wmi/src/wmi_unified_non_tlv.c +++ b/wmi/src/wmi_unified_non_tlv.c @@ -941,6 +941,40 @@ static QDF_STATUS send_peer_delete_all_cmd_non_tlv(wmi_unified_t wmi_handle, return ret; } +/** + * send_peer_ft_roam_cmd_non_tlv() - send PEER BA reset command to fw + * @wmi_handle: wmi handle + * @peer_addr: peer mac addr + * @vdev_id: vdev id + * + * Return: 0 for success or error code + */ + +static QDF_STATUS send_peer_ft_roam_cmd_non_tlv(wmi_unified_t wmi_handle, + uint8_t peer_addr[QDF_MAC_ADDR_SIZE], + uint8_t vdev_id) +{ + wmi_peer_ft_roaming_peer_update_cmd *cmd; + wmi_buf_t buf; + QDF_STATUS ret; + int len = sizeof(wmi_peer_ft_roaming_peer_update_cmd); + + buf = wmi_buf_alloc(wmi_handle, len); + if (!buf) { + WMI_LOGE("%s:wmi_buf_alloc failed", __func__); + return QDF_STATUS_E_NOMEM; + } + cmd = (wmi_peer_ft_roaming_peer_update_cmd *)wmi_buf_data(buf); + WMI_CHAR_ARRAY_TO_MAC_ADDR(peer_addr, &cmd->peer_macaddr); + ret = wmi_unified_cmd_send(wmi_handle, buf, len, + WMI_PEER_FT_ROAMING_PEER_UPDATE_CMDID); + if (QDF_IS_STATUS_ERROR(ret)) { + WMI_LOGE("Failed to send WMI_PEER_FT_ROAMING_PEER_UPDATE_CMDID"); + wmi_buf_free(buf); + } + return ret; +} + /** * convert_host_peer_param_id_to_target_id_non_tlv - convert host peer param_id * to target id. @@ -9918,6 +9952,7 @@ struct wmi_ops non_tlv_ops = { .send_peer_create_cmd = send_peer_create_cmd_non_tlv, .send_peer_delete_cmd = send_peer_delete_cmd_non_tlv, .send_peer_delete_all_cmd = send_peer_delete_all_cmd_non_tlv, + .send_peer_ft_roam_cmd = send_peer_ft_roam_cmd_non_tlv, #ifdef WLAN_SUPPORT_GREEN_AP .send_green_ap_ps_cmd = send_green_ap_ps_cmd_non_tlv, #endif