Преглед на файлове

qcacmn: Add support to configure action frame in HE TB PPDU

Add support to send the action frame in HE TB PPDU configuration
to firmware.

Change-Id: I8f8f63652e0890736266766b283411464f8903b9
CRs-Fixed: 2347028
Kiran Kumar Lokere преди 6 години
родител
ревизия
7ec465930a
променени са 5 файла, в които са добавени 101 реда и са изтрити 0 реда
  1. 3 0
      wmi/inc/wmi_unified_api.h
  2. 12 0
      wmi/inc/wmi_unified_param.h
  3. 3 0
      wmi/inc/wmi_unified_priv.h
  4. 24 0
      wmi/src/wmi_unified_api.c
  5. 59 0
      wmi/src/wmi_unified_tlv.c

+ 3 - 0
wmi/inc/wmi_unified_api.h

@@ -752,6 +752,9 @@ QDF_STATUS wmi_unified_send_regdomain_info_to_fw_cmd(void *wmi_hdl,
 QDF_STATUS wmi_unified_process_fw_mem_dump_cmd(void *wmi_hdl,
 					struct fw_dump_req_param *mem_dump_req);
 
+QDF_STATUS wmi_unified_cfg_action_frm_tb_ppdu_cmd(void *wmi_hdl,
+				struct cfg_action_frm_tb_ppdu_param *cfg_info);
+
 QDF_STATUS wmi_unified_save_fw_version_cmd(void *wmi_hdl,
 		void *evt_buf);
 

+ 12 - 0
wmi/inc/wmi_unified_param.h

@@ -2584,6 +2584,18 @@ struct rcv_pkt_filter_config {
 	struct rcv_pkt_filter_params paramsData[WMI_MAX_NUM_TESTS_PER_FILTER];
 };
 
+/**
+ * struct cfg_action_frm_tb_ppdu_param - action frm in TB PPDU cfg
+ * @cfg - enable/disable
+ * @frm_len - length of the frame
+ * @data - data pointer
+ */
+struct cfg_action_frm_tb_ppdu_param {
+	uint32_t cfg;
+	uint32_t frm_len;
+	uint8_t *data;
+};
+
 #define WMI_MAX_NUM_FW_SEGMENTS 4
 
 /**

+ 3 - 0
wmi/inc/wmi_unified_priv.h

@@ -950,6 +950,9 @@ QDF_STATUS (*send_regdomain_info_to_fw_cmd)(wmi_unified_t wmi_handle,
 QDF_STATUS (*send_process_fw_mem_dump_cmd)(wmi_unified_t wmi_handle,
 					struct fw_dump_req_param *mem_dump_req);
 
+QDF_STATUS (*send_cfg_action_frm_tb_ppdu_cmd)(wmi_unified_t wmi_handle,
+				struct cfg_action_frm_tb_ppdu_param *cfg_info);
+
 QDF_STATUS (*save_fw_version_cmd)(wmi_unified_t wmi_handle, void *evt_buf);
 
 QDF_STATUS (*check_and_update_fw_version_cmd)(wmi_unified_t wmi_hdl, void *ev);

+ 24 - 0
wmi/src/wmi_unified_api.c

@@ -1612,6 +1612,30 @@ QDF_STATUS wmi_unified_send_regdomain_info_to_fw_cmd(void *wmi_hdl,
 	return QDF_STATUS_E_FAILURE;
 }
 
+/**
+ * wmi_unified_cfg_action_frm_tb_ppdu_cmd()-send action frame TB PPDU cfg to FW
+ * @wmi_handle:    Pointer to WMi handle
+ * @cfg_info:      Pointer to cfg msg
+ *
+ * This function sends action frame TB PPDU cfg to firmware
+ *
+ * Return: QDF_STATUS_SUCCESS on success and QDF_STATUS_E_FAILURE for failure
+ *
+ */
+QDF_STATUS
+wmi_unified_cfg_action_frm_tb_ppdu_cmd(void *wmi_hdl,
+				       struct cfg_action_frm_tb_ppdu_param
+				       *cfg_info)
+{
+	wmi_unified_t wmi_handle = (wmi_unified_t) wmi_hdl;
+
+	if (wmi_handle->ops->send_cfg_action_frm_tb_ppdu_cmd)
+		return wmi_handle->ops->send_cfg_action_frm_tb_ppdu_cmd(
+						wmi_handle, cfg_info);
+
+	return QDF_STATUS_E_FAILURE;
+}
+
 /**
  * wmi_unified_save_fw_version_cmd() - save fw version
  * @wmi_handle:      pointer to wmi handle

+ 59 - 0
wmi/src/wmi_unified_tlv.c

@@ -6376,6 +6376,64 @@ static inline void copy_fw_abi_version_tlv(wmi_unified_t wmi_handle,
 			sizeof(wmi_abi_version));
 }
 
+/*
+ * send_cfg_action_frm_tb_ppdu_cmd_tlv() - send action frame tb ppdu cfg to FW
+ * @wmi_handle:    Pointer to WMi handle
+ * @ie_data:       Pointer for ie data
+ *
+ * This function sends action frame tb ppdu cfg to FW
+ *
+ * Return: QDF_STATUS_SUCCESS for success otherwise failure
+ *
+ */
+static QDF_STATUS send_cfg_action_frm_tb_ppdu_cmd_tlv(wmi_unified_t wmi_handle,
+				struct cfg_action_frm_tb_ppdu_param *cfg_msg)
+{
+	wmi_pdev_he_tb_action_frm_cmd_fixed_param *cmd;
+	wmi_buf_t buf;
+	uint8_t *buf_ptr;
+	uint32_t len, frm_len_aligned;
+	QDF_STATUS ret;
+
+	frm_len_aligned = roundup(cfg_msg->frm_len, sizeof(uint32_t));
+	/* Allocate memory for the WMI command */
+	len = sizeof(*cmd) + WMI_TLV_HDR_SIZE + frm_len_aligned;
+
+	buf = wmi_buf_alloc(wmi_handle, len);
+	if (!buf) {
+		WMI_LOGE(FL("wmi_buf_alloc failed"));
+		return QDF_STATUS_E_NOMEM;
+	}
+
+	buf_ptr = wmi_buf_data(buf);
+	qdf_mem_zero(buf_ptr, len);
+
+	/* Populate the WMI command */
+	cmd = (wmi_pdev_he_tb_action_frm_cmd_fixed_param *)buf_ptr;
+
+	WMITLV_SET_HDR(&cmd->tlv_header,
+		WMITLV_TAG_STRUC_wmi_pdev_he_tb_action_frm_cmd_fixed_param,
+		WMITLV_GET_STRUCT_TLVLEN(
+				wmi_pdev_he_tb_action_frm_cmd_fixed_param));
+	cmd->enable = cfg_msg->cfg;
+	cmd->data_len = cfg_msg->frm_len;
+
+	buf_ptr += sizeof(*cmd);
+	WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_BYTE, frm_len_aligned);
+	buf_ptr += WMI_TLV_HDR_SIZE;
+
+	qdf_mem_copy(buf_ptr, cfg_msg->data, cmd->data_len);
+
+	ret = wmi_unified_cmd_send(wmi_handle, buf, len,
+				   WMI_PDEV_HE_TB_ACTION_FRM_CMDID);
+	if (QDF_IS_STATUS_ERROR(ret)) {
+		WMI_LOGE(FL("HE TB action frame cmnd send fail, ret %d"), ret);
+		wmi_buf_free(buf);
+	}
+
+	return ret;
+}
+
 static QDF_STATUS save_fw_version_cmd_tlv(wmi_unified_t wmi_handle, void *evt_buf)
 {
 	WMI_SERVICE_READY_EVENTID_param_tlvs *param_buf;
@@ -11123,6 +11181,7 @@ struct wmi_ops tlv_ops =  {
 	.send_pdev_set_regdomain_cmd =
 				send_pdev_set_regdomain_cmd_tlv,
 	.send_regdomain_info_to_fw_cmd = send_regdomain_info_to_fw_cmd_tlv,
+	.send_cfg_action_frm_tb_ppdu_cmd = send_cfg_action_frm_tb_ppdu_cmd_tlv,
 	.save_fw_version_cmd = save_fw_version_cmd_tlv,
 	.check_and_update_fw_version =
 		 check_and_update_fw_version_cmd_tlv,