Эх сурвалжийг харах

qca-wifi: BA window reset after FT roam

Reset seq number for Station roaming back in FT roam.

Change-Id: I701cf82786ef79bd5fde92ea94957523de807d48
Gurumoorthi Gnanasambandhan 6 жил өмнө
parent
commit
f8184296b6

+ 14 - 0
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.

+ 11 - 0
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)

+ 35 - 0
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