diff --git a/wmi/inc/wmi_unified_api.h b/wmi/inc/wmi_unified_api.h index 8f4ec2122c..941afcbd5a 100644 --- a/wmi/inc/wmi_unified_api.h +++ b/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); diff --git a/wmi/inc/wmi_unified_param.h b/wmi/inc/wmi_unified_param.h index d244df2f52..28889d5750 100644 --- a/wmi/inc/wmi_unified_param.h +++ b/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 /** diff --git a/wmi/inc/wmi_unified_priv.h b/wmi/inc/wmi_unified_priv.h index 7c36d5ede9..b21596af82 100644 --- a/wmi/inc/wmi_unified_priv.h +++ b/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); diff --git a/wmi/src/wmi_unified_api.c b/wmi/src/wmi_unified_api.c index 77be87031f..0ac2041804 100644 --- a/wmi/src/wmi_unified_api.c +++ b/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 diff --git a/wmi/src/wmi_unified_tlv.c b/wmi/src/wmi_unified_tlv.c index 06bb6e05e9..ff9fc5822b 100644 --- a/wmi/src/wmi_unified_tlv.c +++ b/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,