Message ID | 20180815092637.11455-2-govinds@codeaurora.org (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | *** Add support for wifi QMI client handshakes *** | expand |
On Wed 15 Aug 02:26 PDT 2018, Govind Singh wrote: > WLAN qmi server running in Q6 exposes host to target > cold boot qmi handshakes. Add WLAN QMI service helpers > for ath10k wcn3990 qmi client. > Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org> Regards, Bjorn > Signed-off-by: Govind Singh <govinds@codeaurora.org> > --- > .../net/wireless/ath/ath10k/qmi_wlfw_v01.c | 2072 +++++++++++++++++ > .../net/wireless/ath/ath10k/qmi_wlfw_v01.h | 677 ++++++ > 2 files changed, 2749 insertions(+) > create mode 100644 drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c > create mode 100644 drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h > > diff --git a/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c > new file mode 100644 > index 000000000000..ba79c2e4aed6 > --- /dev/null > +++ b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c > @@ -0,0 +1,2072 @@ > +/* > + * Copyright (c) 2018 The Linux Foundation. All rights reserved. > + * > + * Permission to use, copy, modify, and/or distribute this software for any > + * purpose with or without fee is hereby granted, provided that the above > + * copyright notice and this permission notice appear in all copies. > + * > + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES > + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF > + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR > + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES > + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN > + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF > + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. > + */ > + > +#include <linux/soc/qcom/qmi.h> > +#include <linux/types.h> > +#include "qmi_wlfw_v01.h" > + > +static struct qmi_elem_info wlfw_ce_tgt_pipe_cfg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, > + pipe_num), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_pipedir_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, > + pipe_dir), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, > + nentries), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, > + nbytes_max), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, > + flags), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_ce_svc_pipe_cfg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, > + service_id), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_pipedir_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, > + pipe_dir), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, > + pipe_num), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_shadow_reg_cfg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_2_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_shadow_reg_cfg_s_v01, > + id), > + }, > + { > + .data_type = QMI_UNSIGNED_2_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_shadow_reg_cfg_s_v01, > + offset), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_shadow_reg_v2_cfg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_shadow_reg_v2_cfg_s_v01, > + addr), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_memory_region_info_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_memory_region_info_s_v01, > + region_addr), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_memory_region_info_s_v01, > + size), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_memory_region_info_s_v01, > + secure_flag), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_mem_cfg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_cfg_s_v01, > + offset), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_cfg_s_v01, > + size), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_cfg_s_v01, > + secure_flag), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_mem_seg_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_s_v01, > + size), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_mem_type_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_s_v01, > + type), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_s_v01, > + mem_cfg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_MEM_CFG_V01, > + .elem_size = sizeof(struct wlfw_mem_cfg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_s_v01, > + mem_cfg), > + .ei_array = wlfw_mem_cfg_s_v01_ei, > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_mem_seg_resp_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, > + addr), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, > + size), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_mem_type_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, > + type), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_rf_chip_info_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_rf_chip_info_s_v01, > + chip_id), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_rf_chip_info_s_v01, > + chip_family), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_rf_board_info_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_rf_board_info_s_v01, > + board_id), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_soc_info_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_soc_info_s_v01, > + soc_id), > + }, > + {} > +}; > + > +static struct qmi_elem_info wlfw_fw_version_info_s_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_fw_version_info_s_v01, > + fw_version), > + }, > + { > + .data_type = QMI_STRING, > + .elem_len = QMI_WLFW_MAX_TIMESTAMP_LEN_V01 + 1, > + .elem_size = sizeof(char), > + .array_type = NO_ARRAY, > + .tlv_type = 0, > + .offset = offsetof(struct wlfw_fw_version_info_s_v01, > + fw_build_timestamp), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_ind_register_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + fw_ready_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + fw_ready_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + initiate_cal_download_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + initiate_cal_download_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + initiate_cal_update_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + initiate_cal_update_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + msa_ready_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + msa_ready_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + pin_connect_result_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + pin_connect_result_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + client_id_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + client_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x16, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + request_mem_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x16, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + request_mem_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x17, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + mem_ready_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x17, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + mem_ready_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x18, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + fw_init_done_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x18, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + fw_init_done_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x19, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + rejuvenate_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x19, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + rejuvenate_enable), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x1A, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + xo_cal_enable_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x1A, > + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, > + xo_cal_enable), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_ind_register_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, > + fw_status_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, > + fw_status), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_fw_ready_ind_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_msa_ready_ind_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_pin_connect_result_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + pwr_pin_result_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + pwr_pin_result), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + phy_io_pin_result_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + phy_io_pin_result), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + rf_pin_result_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, > + rf_pin_result), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_wlan_mode_req_msg_v01_ei[] = { > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_driver_mode_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, > + mode), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, > + hw_debug_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, > + hw_debug), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_wlan_mode_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_wlan_mode_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_wlan_cfg_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + host_version_valid), > + }, > + { > + .data_type = QMI_STRING, > + .elem_len = QMI_WLFW_MAX_STR_LEN_V01 + 1, > + .elem_size = sizeof(char), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + host_version), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + tgt_cfg_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + tgt_cfg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_CE_V01, > + .elem_size = sizeof(struct wlfw_ce_tgt_pipe_cfg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + tgt_cfg), > + .ei_array = wlfw_ce_tgt_pipe_cfg_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + svc_cfg_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + svc_cfg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_SVC_V01, > + .elem_size = sizeof(struct wlfw_ce_svc_pipe_cfg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + svc_cfg), > + .ei_array = wlfw_ce_svc_pipe_cfg_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_SHADOW_REG_V01, > + .elem_size = sizeof(struct wlfw_shadow_reg_cfg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg), > + .ei_array = wlfw_shadow_reg_cfg_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg_v2_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg_v2_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_SHADOW_REG_V2, > + .elem_size = sizeof(struct wlfw_shadow_reg_v2_cfg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, > + shadow_reg_v2), > + .ei_array = wlfw_shadow_reg_v2_cfg_s_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_wlan_cfg_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_wlan_cfg_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cap_req_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + chip_info_valid), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct wlfw_rf_chip_info_s_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + chip_info), > + .ei_array = wlfw_rf_chip_info_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + board_info_valid), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct wlfw_rf_board_info_s_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + board_info), > + .ei_array = wlfw_rf_board_info_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + soc_info_valid), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct wlfw_soc_info_s_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + soc_info), > + .ei_array = wlfw_soc_info_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + fw_version_info_valid), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct wlfw_fw_version_info_s_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + fw_version_info), > + .ei_array = wlfw_fw_version_info_s_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + fw_build_id_valid), > + }, > + { > + .data_type = QMI_STRING, > + .elem_len = QMI_WLFW_MAX_BUILD_ID_LEN_V01 + 1, > + .elem_size = sizeof(char), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + fw_build_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + num_macs_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_cap_resp_msg_v01, > + num_macs), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_bdf_download_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + valid), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + file_id_valid), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + file_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + total_size_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + total_size), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + seg_id_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + seg_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + data_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + data_len), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + data), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + end_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + end), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + bdf_type_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x15, > + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, > + bdf_type), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_bdf_download_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_bdf_download_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_report_req_msg_v01_ei[] = { > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, > + meta_data_len), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = QMI_WLFW_MAX_NUM_CAL_V01, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, > + meta_data), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, > + xo_cal_data_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, > + xo_cal_data), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_report_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_cal_report_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_initiate_cal_download_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_initiate_cal_download_ind_msg_v01, > + cal_id), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_download_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + valid), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + file_id_valid), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + file_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + total_size_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + total_size), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + seg_id_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + seg_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + data_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + data_len), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + data), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + end_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, > + end), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_download_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_cal_download_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_initiate_cal_update_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_initiate_cal_update_ind_msg_v01, > + cal_id), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_initiate_cal_update_ind_msg_v01, > + total_size), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_update_req_msg_v01_ei[] = { > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_cal_update_req_msg_v01, > + cal_id), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_cal_update_req_msg_v01, > + seg_id), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_cal_update_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + file_id_valid), > + }, > + { > + .data_type = QMI_SIGNED_4_BYTE_ENUM, > + .elem_len = 1, > + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + file_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + total_size_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + total_size), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + seg_id_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + seg_id), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + data_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + data_len), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + data), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + end_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x14, > + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, > + end), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_msa_info_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_msa_info_req_msg_v01, > + msa_addr), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_msa_info_req_msg_v01, > + size), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_msa_info_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x03, > + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, > + mem_region_info_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_MEM_REG_V01, > + .elem_size = sizeof(struct wlfw_memory_region_info_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x03, > + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, > + mem_region_info), > + .ei_array = wlfw_memory_region_info_s_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_msa_ready_req_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_msa_ready_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_msa_ready_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_ini_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ini_req_msg_v01, > + enablefwlog_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_ini_req_msg_v01, > + enablefwlog), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_ini_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_ini_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_athdiag_read_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, > + offset), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, > + mem_type), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x03, > + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, > + data_len), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_athdiag_read_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, > + data_valid), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, > + data_len), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, > + data), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_athdiag_write_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, > + offset), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, > + mem_type), > + }, > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x03, > + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, > + data_len), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x03, > + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, > + data), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_athdiag_write_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_athdiag_write_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_vbatt_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_vbatt_req_msg_v01, > + voltage_uv), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_vbatt_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_vbatt_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_mac_addr_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_mac_addr_req_msg_v01, > + mac_addr_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = QMI_WLFW_MAC_ADDR_SIZE_V01, > + .elem_size = sizeof(u8), > + .array_type = STATIC_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_mac_addr_req_msg_v01, > + mac_addr), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_mac_addr_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_mac_addr_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_host_cap_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_host_cap_req_msg_v01, > + daemon_support_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_host_cap_req_msg_v01, > + daemon_support), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_host_cap_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_host_cap_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_request_mem_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_request_mem_ind_msg_v01, > + mem_seg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_MEM_SEG_V01, > + .elem_size = sizeof(struct wlfw_mem_seg_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_request_mem_ind_msg_v01, > + mem_seg), > + .ei_array = wlfw_mem_seg_s_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_respond_mem_req_msg_v01_ei[] = { > + { > + .data_type = QMI_DATA_LEN, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_respond_mem_req_msg_v01, > + mem_seg_len), > + }, > + { > + .data_type = QMI_STRUCT, > + .elem_len = QMI_WLFW_MAX_NUM_MEM_SEG_V01, > + .elem_size = sizeof(struct wlfw_mem_seg_resp_s_v01), > + .array_type = VAR_LEN_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_respond_mem_req_msg_v01, > + mem_seg), > + .ei_array = wlfw_mem_seg_resp_s_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_respond_mem_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_respond_mem_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_mem_ready_ind_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_fw_init_done_ind_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_rejuvenate_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + cause_for_rejuvenation_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + cause_for_rejuvenation), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + requesting_sub_system_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + requesting_sub_system), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + line_number_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_2_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u16), > + .array_type = NO_ARRAY, > + .tlv_type = 0x12, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + line_number), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + function_name_valid), > + }, > + { > + .data_type = QMI_STRING, > + .elem_len = QMI_WLFW_FUNCTION_NAME_LEN_V01 + 1, > + .elem_size = sizeof(char), > + .array_type = NO_ARRAY, > + .tlv_type = 0x13, > + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, > + function_name), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_rejuvenate_ack_req_msg_v01_ei[] = { > + {} > +}; > + > +struct qmi_elem_info wlfw_rejuvenate_ack_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_rejuvenate_ack_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_dynamic_feature_mask_req_msg_v01_ei[] = { > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_req_msg_v01, > + mask_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_req_msg_v01, > + mask), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_dynamic_feature_mask_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, > + prev_mask_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x10, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, > + prev_mask), > + }, > + { > + .data_type = QMI_OPT_FLAG, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, > + curr_mask_valid), > + }, > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x11, > + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, > + curr_mask), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_m3_info_req_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_8_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u64), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_m3_info_req_msg_v01, > + addr), > + }, > + { > + .data_type = QMI_UNSIGNED_4_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u32), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_m3_info_req_msg_v01, > + size), > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_m3_info_resp_msg_v01_ei[] = { > + { > + .data_type = QMI_STRUCT, > + .elem_len = 1, > + .elem_size = sizeof(struct qmi_response_type_v01), > + .array_type = NO_ARRAY, > + .tlv_type = 0x02, > + .offset = offsetof(struct wlfw_m3_info_resp_msg_v01, > + resp), > + .ei_array = qmi_response_type_v01_ei, > + }, > + {} > +}; > + > +struct qmi_elem_info wlfw_xo_cal_ind_msg_v01_ei[] = { > + { > + .data_type = QMI_UNSIGNED_1_BYTE, > + .elem_len = 1, > + .elem_size = sizeof(u8), > + .array_type = NO_ARRAY, > + .tlv_type = 0x01, > + .offset = offsetof(struct wlfw_xo_cal_ind_msg_v01, > + xo_cal_data), > + }, > + {} > +}; > diff --git a/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h > new file mode 100644 > index 000000000000..c5e3870b8871 > --- /dev/null > +++ b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h > @@ -0,0 +1,677 @@ > +/* > + * Copyright (c) 2018 The Linux Foundation. All rights reserved. > + * > + * Permission to use, copy, modify, and/or distribute this software for any > + * purpose with or without fee is hereby granted, provided that the above > + * copyright notice and this permission notice appear in all copies. > + * > + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES > + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF > + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR > + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES > + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN > + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF > + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. > + */ > + > +#ifndef WCN3990_QMI_SVC_V01_H > +#define WCN3990_QMI_SVC_V01_H > + > +#define WLFW_SERVICE_ID_V01 0x45 > +#define WLFW_SERVICE_VERS_V01 0x01 > + > +#define QMI_WLFW_BDF_DOWNLOAD_REQ_V01 0x0025 > +#define QMI_WLFW_MEM_READY_IND_V01 0x0037 > +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_RESP_V01 0x003B > +#define QMI_WLFW_INITIATE_CAL_UPDATE_IND_V01 0x002A > +#define QMI_WLFW_HOST_CAP_REQ_V01 0x0034 > +#define QMI_WLFW_M3_INFO_REQ_V01 0x003C > +#define QMI_WLFW_CAP_REQ_V01 0x0024 > +#define QMI_WLFW_FW_INIT_DONE_IND_V01 0x0038 > +#define QMI_WLFW_CAL_REPORT_REQ_V01 0x0026 > +#define QMI_WLFW_M3_INFO_RESP_V01 0x003C > +#define QMI_WLFW_CAL_UPDATE_RESP_V01 0x0029 > +#define QMI_WLFW_CAL_DOWNLOAD_RESP_V01 0x0027 > +#define QMI_WLFW_XO_CAL_IND_V01 0x003D > +#define QMI_WLFW_INI_RESP_V01 0x002F > +#define QMI_WLFW_CAL_REPORT_RESP_V01 0x0026 > +#define QMI_WLFW_MAC_ADDR_RESP_V01 0x0033 > +#define QMI_WLFW_INITIATE_CAL_DOWNLOAD_IND_V01 0x0028 > +#define QMI_WLFW_HOST_CAP_RESP_V01 0x0034 > +#define QMI_WLFW_MSA_READY_IND_V01 0x002B > +#define QMI_WLFW_ATHDIAG_WRITE_RESP_V01 0x0031 > +#define QMI_WLFW_WLAN_MODE_REQ_V01 0x0022 > +#define QMI_WLFW_IND_REGISTER_REQ_V01 0x0020 > +#define QMI_WLFW_WLAN_CFG_RESP_V01 0x0023 > +#define QMI_WLFW_REQUEST_MEM_IND_V01 0x0035 > +#define QMI_WLFW_REJUVENATE_IND_V01 0x0039 > +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_REQ_V01 0x003B > +#define QMI_WLFW_ATHDIAG_WRITE_REQ_V01 0x0031 > +#define QMI_WLFW_WLAN_MODE_RESP_V01 0x0022 > +#define QMI_WLFW_RESPOND_MEM_REQ_V01 0x0036 > +#define QMI_WLFW_PIN_CONNECT_RESULT_IND_V01 0x002C > +#define QMI_WLFW_FW_READY_IND_V01 0x0021 > +#define QMI_WLFW_MSA_READY_RESP_V01 0x002E > +#define QMI_WLFW_CAL_UPDATE_REQ_V01 0x0029 > +#define QMI_WLFW_INI_REQ_V01 0x002F > +#define QMI_WLFW_BDF_DOWNLOAD_RESP_V01 0x0025 > +#define QMI_WLFW_REJUVENATE_ACK_RESP_V01 0x003A > +#define QMI_WLFW_MSA_INFO_RESP_V01 0x002D > +#define QMI_WLFW_MSA_READY_REQ_V01 0x002E > +#define QMI_WLFW_CAP_RESP_V01 0x0024 > +#define QMI_WLFW_REJUVENATE_ACK_REQ_V01 0x003A > +#define QMI_WLFW_ATHDIAG_READ_RESP_V01 0x0030 > +#define QMI_WLFW_VBATT_REQ_V01 0x0032 > +#define QMI_WLFW_MAC_ADDR_REQ_V01 0x0033 > +#define QMI_WLFW_RESPOND_MEM_RESP_V01 0x0036 > +#define QMI_WLFW_VBATT_RESP_V01 0x0032 > +#define QMI_WLFW_MSA_INFO_REQ_V01 0x002D > +#define QMI_WLFW_CAL_DOWNLOAD_REQ_V01 0x0027 > +#define QMI_WLFW_ATHDIAG_READ_REQ_V01 0x0030 > +#define QMI_WLFW_WLAN_CFG_REQ_V01 0x0023 > +#define QMI_WLFW_IND_REGISTER_RESP_V01 0x0020 > + > +#define QMI_WLFW_MAX_MEM_REG_V01 2 > +#define QMI_WLFW_MAX_NUM_MEM_SEG_V01 16 > +#define QMI_WLFW_MAX_NUM_CAL_V01 5 > +#define QMI_WLFW_MAX_DATA_SIZE_V01 6144 > +#define QMI_WLFW_FUNCTION_NAME_LEN_V01 128 > +#define QMI_WLFW_MAX_NUM_CE_V01 12 > +#define QMI_WLFW_MAX_TIMESTAMP_LEN_V01 32 > +#define QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01 6144 > +#define QMI_WLFW_MAX_NUM_GPIO_V01 32 > +#define QMI_WLFW_MAX_BUILD_ID_LEN_V01 128 > +#define QMI_WLFW_MAX_NUM_MEM_CFG_V01 2 > +#define QMI_WLFW_MAX_STR_LEN_V01 16 > +#define QMI_WLFW_MAX_NUM_SHADOW_REG_V01 24 > +#define QMI_WLFW_MAC_ADDR_SIZE_V01 6 > +#define QMI_WLFW_MAX_SHADOW_REG_V2 36 > +#define QMI_WLFW_MAX_NUM_SVC_V01 24 > + > +enum wlfw_driver_mode_enum_v01 { > + QMI_WLFW_MISSION_V01 = 0, > + QMI_WLFW_FTM_V01 = 1, > + QMI_WLFW_EPPING_V01 = 2, > + QMI_WLFW_WALTEST_V01 = 3, > + QMI_WLFW_OFF_V01 = 4, > + QMI_WLFW_CCPM_V01 = 5, > + QMI_WLFW_QVIT_V01 = 6, > + QMI_WLFW_CALIBRATION_V01 = 7, > +}; > + > +enum wlfw_cal_temp_id_enum_v01 { > + QMI_WLFW_CAL_TEMP_IDX_0_V01 = 0, > + QMI_WLFW_CAL_TEMP_IDX_1_V01 = 1, > + QMI_WLFW_CAL_TEMP_IDX_2_V01 = 2, > + QMI_WLFW_CAL_TEMP_IDX_3_V01 = 3, > + QMI_WLFW_CAL_TEMP_IDX_4_V01 = 4, > +}; > + > +enum wlfw_pipedir_enum_v01 { > + QMI_WLFW_PIPEDIR_NONE_V01 = 0, > + QMI_WLFW_PIPEDIR_IN_V01 = 1, > + QMI_WLFW_PIPEDIR_OUT_V01 = 2, > + QMI_WLFW_PIPEDIR_INOUT_V01 = 3, > +}; > + > +enum wlfw_mem_type_enum_v01 { > + QMI_WLFW_MEM_TYPE_MSA_V01 = 0, > + QMI_WLFW_MEM_TYPE_DDR_V01 = 1, > +}; > + > +#define QMI_WLFW_CE_ATTR_FLAGS_V01 ((u32)0x00) > +#define QMI_WLFW_CE_ATTR_NO_SNOOP_V01 ((u32)0x01) > +#define QMI_WLFW_CE_ATTR_BYTE_SWAP_DATA_V01 ((u32)0x02) > +#define QMI_WLFW_CE_ATTR_SWIZZLE_DESCRIPTORS_V01 ((u32)0x04) > +#define QMI_WLFW_CE_ATTR_DISABLE_INTR_V01 ((u32)0x08) > +#define QMI_WLFW_CE_ATTR_ENABLE_POLL_V01 ((u32)0x10) > + > +#define QMI_WLFW_ALREADY_REGISTERED_V01 ((u64)0x01ULL) > +#define QMI_WLFW_FW_READY_V01 ((u64)0x02ULL) > +#define QMI_WLFW_MSA_READY_V01 ((u64)0x04ULL) > +#define QMI_WLFW_MEM_READY_V01 ((u64)0x08ULL) > +#define QMI_WLFW_FW_INIT_DONE_V01 ((u64)0x10ULL) > + > +#define QMI_WLFW_FW_REJUVENATE_V01 ((u64)0x01ULL) > + > +struct wlfw_ce_tgt_pipe_cfg_s_v01 { > + __le32 pipe_num; > + __le32 pipe_dir; > + __le32 nentries; > + __le32 nbytes_max; > + __le32 flags; > +}; > + > +struct wlfw_ce_svc_pipe_cfg_s_v01 { > + __le32 service_id; > + __le32 pipe_dir; > + __le32 pipe_num; > +}; > + > +struct wlfw_shadow_reg_cfg_s_v01 { > + u16 id; > + u16 offset; > +}; > + > +struct wlfw_shadow_reg_v2_cfg_s_v01 { > + u32 addr; > +}; > + > +struct wlfw_memory_region_info_s_v01 { > + u64 region_addr; > + u32 size; > + u8 secure_flag; > +}; > + > +struct wlfw_mem_cfg_s_v01 { > + u64 offset; > + u32 size; > + u8 secure_flag; > +}; > + > +struct wlfw_mem_seg_s_v01 { > + u32 size; > + enum wlfw_mem_type_enum_v01 type; > + u32 mem_cfg_len; > + struct wlfw_mem_cfg_s_v01 mem_cfg[QMI_WLFW_MAX_NUM_MEM_CFG_V01]; > +}; > + > +struct wlfw_mem_seg_resp_s_v01 { > + u64 addr; > + u32 size; > + enum wlfw_mem_type_enum_v01 type; > +}; > + > +struct wlfw_rf_chip_info_s_v01 { > + u32 chip_id; > + u32 chip_family; > +}; > + > +struct wlfw_rf_board_info_s_v01 { > + u32 board_id; > +}; > + > +struct wlfw_soc_info_s_v01 { > + u32 soc_id; > +}; > + > +struct wlfw_fw_version_info_s_v01 { > + u32 fw_version; > + char fw_build_timestamp[QMI_WLFW_MAX_TIMESTAMP_LEN_V01 + 1]; > +}; > + > +struct wlfw_ind_register_req_msg_v01 { > + u8 fw_ready_enable_valid; > + u8 fw_ready_enable; > + u8 initiate_cal_download_enable_valid; > + u8 initiate_cal_download_enable; > + u8 initiate_cal_update_enable_valid; > + u8 initiate_cal_update_enable; > + u8 msa_ready_enable_valid; > + u8 msa_ready_enable; > + u8 pin_connect_result_enable_valid; > + u8 pin_connect_result_enable; > + u8 client_id_valid; > + u32 client_id; > + u8 request_mem_enable_valid; > + u8 request_mem_enable; > + u8 mem_ready_enable_valid; > + u8 mem_ready_enable; > + u8 fw_init_done_enable_valid; > + u8 fw_init_done_enable; > + u8 rejuvenate_enable_valid; > + u32 rejuvenate_enable; > + u8 xo_cal_enable_valid; > + u8 xo_cal_enable; > +}; > + > +#define WLFW_IND_REGISTER_REQ_MSG_V01_MAX_MSG_LEN 50 > +extern struct qmi_elem_info wlfw_ind_register_req_msg_v01_ei[]; > + > +struct wlfw_ind_register_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u8 fw_status_valid; > + u64 fw_status; > +}; > + > +#define WLFW_IND_REGISTER_RESP_MSG_V01_MAX_MSG_LEN 18 > +extern struct qmi_elem_info wlfw_ind_register_resp_msg_v01_ei[]; > + > +struct wlfw_fw_ready_ind_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_FW_READY_IND_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_fw_ready_ind_msg_v01_ei[]; > + > +struct wlfw_msa_ready_ind_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_MSA_READY_IND_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_msa_ready_ind_msg_v01_ei[]; > + > +struct wlfw_pin_connect_result_ind_msg_v01 { > + u8 pwr_pin_result_valid; > + u32 pwr_pin_result; > + u8 phy_io_pin_result_valid; > + u32 phy_io_pin_result; > + u8 rf_pin_result_valid; > + u32 rf_pin_result; > +}; > + > +#define WLFW_PIN_CONNECT_RESULT_IND_MSG_V01_MAX_MSG_LEN 21 > +extern struct qmi_elem_info wlfw_pin_connect_result_ind_msg_v01_ei[]; > + > +struct wlfw_wlan_mode_req_msg_v01 { > + enum wlfw_driver_mode_enum_v01 mode; > + u8 hw_debug_valid; > + u8 hw_debug; > +}; > + > +#define WLFW_WLAN_MODE_REQ_MSG_V01_MAX_MSG_LEN 11 > +extern struct qmi_elem_info wlfw_wlan_mode_req_msg_v01_ei[]; > + > +struct wlfw_wlan_mode_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_WLAN_MODE_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_wlan_mode_resp_msg_v01_ei[]; > + > +struct wlfw_wlan_cfg_req_msg_v01 { > + u8 host_version_valid; > + char host_version[QMI_WLFW_MAX_STR_LEN_V01 + 1]; > + u8 tgt_cfg_valid; > + u32 tgt_cfg_len; > + struct wlfw_ce_tgt_pipe_cfg_s_v01 tgt_cfg[QMI_WLFW_MAX_NUM_CE_V01]; > + u8 svc_cfg_valid; > + u32 svc_cfg_len; > + struct wlfw_ce_svc_pipe_cfg_s_v01 svc_cfg[QMI_WLFW_MAX_NUM_SVC_V01]; > + u8 shadow_reg_valid; > + u32 shadow_reg_len; > + struct wlfw_shadow_reg_cfg_s_v01 shadow_reg[QMI_WLFW_MAX_NUM_SHADOW_REG_V01]; > + u8 shadow_reg_v2_valid; > + u32 shadow_reg_v2_len; > + struct wlfw_shadow_reg_v2_cfg_s_v01 shadow_reg_v2[QMI_WLFW_MAX_SHADOW_REG_V2]; > +}; > + > +#define WLFW_WLAN_CFG_REQ_MSG_V01_MAX_MSG_LEN 803 > +extern struct qmi_elem_info wlfw_wlan_cfg_req_msg_v01_ei[]; > + > +struct wlfw_wlan_cfg_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_WLAN_CFG_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_wlan_cfg_resp_msg_v01_ei[]; > + > +struct wlfw_cap_req_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_CAP_REQ_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_cap_req_msg_v01_ei[]; > + > +struct wlfw_cap_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u8 chip_info_valid; > + struct wlfw_rf_chip_info_s_v01 chip_info; > + u8 board_info_valid; > + struct wlfw_rf_board_info_s_v01 board_info; > + u8 soc_info_valid; > + struct wlfw_soc_info_s_v01 soc_info; > + u8 fw_version_info_valid; > + struct wlfw_fw_version_info_s_v01 fw_version_info; > + u8 fw_build_id_valid; > + char fw_build_id[QMI_WLFW_MAX_BUILD_ID_LEN_V01 + 1]; > + u8 num_macs_valid; > + u8 num_macs; > +}; > + > +#define WLFW_CAP_RESP_MSG_V01_MAX_MSG_LEN 207 > +extern struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[]; > + > +struct wlfw_bdf_download_req_msg_v01 { > + u8 valid; > + u8 file_id_valid; > + enum wlfw_cal_temp_id_enum_v01 file_id; > + u8 total_size_valid; > + u32 total_size; > + u8 seg_id_valid; > + u32 seg_id; > + u8 data_valid; > + u32 data_len; > + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; > + u8 end_valid; > + u8 end; > + u8 bdf_type_valid; > + u8 bdf_type; > +}; > + > +#define WLFW_BDF_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6182 > +extern struct qmi_elem_info wlfw_bdf_download_req_msg_v01_ei[]; > + > +struct wlfw_bdf_download_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_BDF_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_bdf_download_resp_msg_v01_ei[]; > + > +struct wlfw_cal_report_req_msg_v01 { > + u32 meta_data_len; > + enum wlfw_cal_temp_id_enum_v01 meta_data[QMI_WLFW_MAX_NUM_CAL_V01]; > + u8 xo_cal_data_valid; > + u8 xo_cal_data; > +}; > + > +#define WLFW_CAL_REPORT_REQ_MSG_V01_MAX_MSG_LEN 28 > +extern struct qmi_elem_info wlfw_cal_report_req_msg_v01_ei[]; > + > +struct wlfw_cal_report_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_CAL_REPORT_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_cal_report_resp_msg_v01_ei[]; > + > +struct wlfw_initiate_cal_download_ind_msg_v01 { > + enum wlfw_cal_temp_id_enum_v01 cal_id; > +}; > + > +#define WLFW_INITIATE_CAL_DOWNLOAD_IND_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_initiate_cal_download_ind_msg_v01_ei[]; > + > +struct wlfw_cal_download_req_msg_v01 { > + u8 valid; > + u8 file_id_valid; > + enum wlfw_cal_temp_id_enum_v01 file_id; > + u8 total_size_valid; > + u32 total_size; > + u8 seg_id_valid; > + u32 seg_id; > + u8 data_valid; > + u32 data_len; > + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; > + u8 end_valid; > + u8 end; > +}; > + > +#define WLFW_CAL_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6178 > +extern struct qmi_elem_info wlfw_cal_download_req_msg_v01_ei[]; > + > +struct wlfw_cal_download_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_CAL_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_cal_download_resp_msg_v01_ei[]; > + > +struct wlfw_initiate_cal_update_ind_msg_v01 { > + enum wlfw_cal_temp_id_enum_v01 cal_id; > + u32 total_size; > +}; > + > +#define WLFW_INITIATE_CAL_UPDATE_IND_MSG_V01_MAX_MSG_LEN 14 > +extern struct qmi_elem_info wlfw_initiate_cal_update_ind_msg_v01_ei[]; > + > +struct wlfw_cal_update_req_msg_v01 { > + enum wlfw_cal_temp_id_enum_v01 cal_id; > + u32 seg_id; > +}; > + > +#define WLFW_CAL_UPDATE_REQ_MSG_V01_MAX_MSG_LEN 14 > +extern struct qmi_elem_info wlfw_cal_update_req_msg_v01_ei[]; > + > +struct wlfw_cal_update_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u8 file_id_valid; > + enum wlfw_cal_temp_id_enum_v01 file_id; > + u8 total_size_valid; > + u32 total_size; > + u8 seg_id_valid; > + u32 seg_id; > + u8 data_valid; > + u32 data_len; > + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; > + u8 end_valid; > + u8 end; > +}; > + > +#define WLFW_CAL_UPDATE_RESP_MSG_V01_MAX_MSG_LEN 6181 > +extern struct qmi_elem_info wlfw_cal_update_resp_msg_v01_ei[]; > + > +struct wlfw_msa_info_req_msg_v01 { > + u64 msa_addr; > + u32 size; > +}; > + > +#define WLFW_MSA_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 > +extern struct qmi_elem_info wlfw_msa_info_req_msg_v01_ei[]; > + > +struct wlfw_msa_info_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u32 mem_region_info_len; > + struct wlfw_memory_region_info_s_v01 mem_region_info[QMI_WLFW_MAX_MEM_REG_V01]; > +}; > + > +#define WLFW_MSA_INFO_RESP_MSG_V01_MAX_MSG_LEN 37 > +extern struct qmi_elem_info wlfw_msa_info_resp_msg_v01_ei[]; > + > +struct wlfw_msa_ready_req_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_MSA_READY_REQ_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_msa_ready_req_msg_v01_ei[]; > + > +struct wlfw_msa_ready_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_MSA_READY_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_msa_ready_resp_msg_v01_ei[]; > + > +struct wlfw_ini_req_msg_v01 { > + u8 enablefwlog_valid; > + u8 enablefwlog; > +}; > + > +#define WLFW_INI_REQ_MSG_V01_MAX_MSG_LEN 4 > +extern struct qmi_elem_info wlfw_ini_req_msg_v01_ei[]; > + > +struct wlfw_ini_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_INI_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_ini_resp_msg_v01_ei[]; > + > +struct wlfw_athdiag_read_req_msg_v01 { > + u32 offset; > + u32 mem_type; > + u32 data_len; > +}; > + > +#define WLFW_ATHDIAG_READ_REQ_MSG_V01_MAX_MSG_LEN 21 > +extern struct qmi_elem_info wlfw_athdiag_read_req_msg_v01_ei[]; > + > +struct wlfw_athdiag_read_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u8 data_valid; > + u32 data_len; > + u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; > +}; > + > +#define WLFW_ATHDIAG_READ_RESP_MSG_V01_MAX_MSG_LEN 6156 > +extern struct qmi_elem_info wlfw_athdiag_read_resp_msg_v01_ei[]; > + > +struct wlfw_athdiag_write_req_msg_v01 { > + u32 offset; > + u32 mem_type; > + u32 data_len; > + u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; > +}; > + > +#define WLFW_ATHDIAG_WRITE_REQ_MSG_V01_MAX_MSG_LEN 6163 > +extern struct qmi_elem_info wlfw_athdiag_write_req_msg_v01_ei[]; > + > +struct wlfw_athdiag_write_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_ATHDIAG_WRITE_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_athdiag_write_resp_msg_v01_ei[]; > + > +struct wlfw_vbatt_req_msg_v01 { > + u64 voltage_uv; > +}; > + > +#define WLFW_VBATT_REQ_MSG_V01_MAX_MSG_LEN 11 > +extern struct qmi_elem_info wlfw_vbatt_req_msg_v01_ei[]; > + > +struct wlfw_vbatt_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_VBATT_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_vbatt_resp_msg_v01_ei[]; > + > +struct wlfw_mac_addr_req_msg_v01 { > + u8 mac_addr_valid; > + u8 mac_addr[QMI_WLFW_MAC_ADDR_SIZE_V01]; > +}; > + > +#define WLFW_MAC_ADDR_REQ_MSG_V01_MAX_MSG_LEN 9 > +extern struct qmi_elem_info wlfw_mac_addr_req_msg_v01_ei[]; > + > +struct wlfw_mac_addr_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_MAC_ADDR_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_mac_addr_resp_msg_v01_ei[]; > + > +struct wlfw_host_cap_req_msg_v01 { > + u8 daemon_support_valid; > + u8 daemon_support; > +}; > + > +#define WLFW_HOST_CAP_REQ_MSG_V01_MAX_MSG_LEN 4 > +extern struct qmi_elem_info wlfw_host_cap_req_msg_v01_ei[]; > + > +struct wlfw_host_cap_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_HOST_CAP_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_host_cap_resp_msg_v01_ei[]; > + > +struct wlfw_request_mem_ind_msg_v01 { > + u32 mem_seg_len; > + struct wlfw_mem_seg_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; > +}; > + > +#define WLFW_REQUEST_MEM_IND_MSG_V01_MAX_MSG_LEN 564 > +extern struct qmi_elem_info wlfw_request_mem_ind_msg_v01_ei[]; > + > +struct wlfw_respond_mem_req_msg_v01 { > + u32 mem_seg_len; > + struct wlfw_mem_seg_resp_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; > +}; > + > +#define WLFW_RESPOND_MEM_REQ_MSG_V01_MAX_MSG_LEN 260 > +extern struct qmi_elem_info wlfw_respond_mem_req_msg_v01_ei[]; > + > +struct wlfw_respond_mem_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_RESPOND_MEM_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_respond_mem_resp_msg_v01_ei[]; > + > +struct wlfw_mem_ready_ind_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_MEM_READY_IND_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_mem_ready_ind_msg_v01_ei[]; > + > +struct wlfw_fw_init_done_ind_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_FW_INIT_DONE_IND_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_fw_init_done_ind_msg_v01_ei[]; > + > +struct wlfw_rejuvenate_ind_msg_v01 { > + u8 cause_for_rejuvenation_valid; > + u8 cause_for_rejuvenation; > + u8 requesting_sub_system_valid; > + u8 requesting_sub_system; > + u8 line_number_valid; > + u16 line_number; > + u8 function_name_valid; > + char function_name[QMI_WLFW_FUNCTION_NAME_LEN_V01 + 1]; > +}; > + > +#define WLFW_REJUVENATE_IND_MSG_V01_MAX_MSG_LEN 144 > +extern struct qmi_elem_info wlfw_rejuvenate_ind_msg_v01_ei[]; > + > +struct wlfw_rejuvenate_ack_req_msg_v01 { > + char placeholder; > +}; > + > +#define WLFW_REJUVENATE_ACK_REQ_MSG_V01_MAX_MSG_LEN 0 > +extern struct qmi_elem_info wlfw_rejuvenate_ack_req_msg_v01_ei[]; > + > +struct wlfw_rejuvenate_ack_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_REJUVENATE_ACK_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_rejuvenate_ack_resp_msg_v01_ei[]; > + > +struct wlfw_dynamic_feature_mask_req_msg_v01 { > + u8 mask_valid; > + u64 mask; > +}; > + > +#define WLFW_DYNAMIC_FEATURE_MASK_REQ_MSG_V01_MAX_MSG_LEN 11 > +extern struct qmi_elem_info wlfw_dynamic_feature_mask_req_msg_v01_ei[]; > + > +struct wlfw_dynamic_feature_mask_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > + u8 prev_mask_valid; > + u64 prev_mask; > + u8 curr_mask_valid; > + u64 curr_mask; > +}; > + > +#define WLFW_DYNAMIC_FEATURE_MASK_RESP_MSG_V01_MAX_MSG_LEN 29 > +extern struct qmi_elem_info wlfw_dynamic_feature_mask_resp_msg_v01_ei[]; > + > +struct wlfw_m3_info_req_msg_v01 { > + u64 addr; > + u32 size; > +}; > + > +#define WLFW_M3_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 > +extern struct qmi_elem_info wlfw_m3_info_req_msg_v01_ei[]; > + > +struct wlfw_m3_info_resp_msg_v01 { > + struct qmi_response_type_v01 resp; > +}; > + > +#define WLFW_M3_INFO_RESP_MSG_V01_MAX_MSG_LEN 7 > +extern struct qmi_elem_info wlfw_m3_info_resp_msg_v01_ei[]; > + > +struct wlfw_xo_cal_ind_msg_v01 { > + u8 xo_cal_data; > +}; > + > +#define WLFW_XO_CAL_IND_MSG_V01_MAX_MSG_LEN 4 > +extern struct qmi_elem_info wlfw_xo_cal_ind_msg_v01_ei[]; > + > +#endif > -- > 2.17.0 >
Govind Singh <govinds@codeaurora.org> wrote: > WLAN qmi server running in Q6 exposes host to target > cold boot qmi handshakes. Add WLAN QMI service helpers > for ath10k wcn3990 qmi client. > > Signed-off-by: Govind Singh <govinds@codeaurora.org> > Reviewed-by: Bjorn Andersson <bjorn.andersson@linaro.org> > Acked-by: Niklas Cassel <niklas.cassel@linaro.org> > Reviewed-by: Brian Norris <briannorris@chromium.org> > Signed-off-by: Kalle Valo <kvalo@codeaurora.org> 6 patches applied to ath-next branch of ath.git, thanks. bc17d4b90cdd ath10k: add qmi service helpers for wcn3990 qmi client 22e8a4602738 ath10k: add support to create boardname for non-bmi target 2b741a8aaa34 dt: bindings: add bindings for msa memory region cc53aabcc283 firmware: qcom: scm: Add WLAN VMID for Qualcomm SCM interface 35a665766737 ath10k: add debug mask for QMI layer ba94c753ccb4 ath10k: add QMI message handshake for wcn3990 client
diff --git a/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c new file mode 100644 index 000000000000..ba79c2e4aed6 --- /dev/null +++ b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c @@ -0,0 +1,2072 @@ +/* + * Copyright (c) 2018 The Linux Foundation. All rights reserved. + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#include <linux/soc/qcom/qmi.h> +#include <linux/types.h> +#include "qmi_wlfw_v01.h" + +static struct qmi_elem_info wlfw_ce_tgt_pipe_cfg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, + pipe_num), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_pipedir_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, + pipe_dir), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, + nentries), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, + nbytes_max), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_tgt_pipe_cfg_s_v01, + flags), + }, + {} +}; + +static struct qmi_elem_info wlfw_ce_svc_pipe_cfg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, + service_id), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_pipedir_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, + pipe_dir), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_ce_svc_pipe_cfg_s_v01, + pipe_num), + }, + {} +}; + +static struct qmi_elem_info wlfw_shadow_reg_cfg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_2_BYTE, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_shadow_reg_cfg_s_v01, + id), + }, + { + .data_type = QMI_UNSIGNED_2_BYTE, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_shadow_reg_cfg_s_v01, + offset), + }, + {} +}; + +static struct qmi_elem_info wlfw_shadow_reg_v2_cfg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_shadow_reg_v2_cfg_s_v01, + addr), + }, + {} +}; + +static struct qmi_elem_info wlfw_memory_region_info_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_memory_region_info_s_v01, + region_addr), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_memory_region_info_s_v01, + size), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_memory_region_info_s_v01, + secure_flag), + }, + {} +}; + +static struct qmi_elem_info wlfw_mem_cfg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_cfg_s_v01, + offset), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_cfg_s_v01, + size), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_cfg_s_v01, + secure_flag), + }, + {} +}; + +static struct qmi_elem_info wlfw_mem_seg_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_s_v01, + size), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_mem_type_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_s_v01, + type), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_s_v01, + mem_cfg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_MEM_CFG_V01, + .elem_size = sizeof(struct wlfw_mem_cfg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_s_v01, + mem_cfg), + .ei_array = wlfw_mem_cfg_s_v01_ei, + }, + {} +}; + +static struct qmi_elem_info wlfw_mem_seg_resp_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, + addr), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, + size), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_mem_type_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_mem_seg_resp_s_v01, + type), + }, + {} +}; + +static struct qmi_elem_info wlfw_rf_chip_info_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_rf_chip_info_s_v01, + chip_id), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_rf_chip_info_s_v01, + chip_family), + }, + {} +}; + +static struct qmi_elem_info wlfw_rf_board_info_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_rf_board_info_s_v01, + board_id), + }, + {} +}; + +static struct qmi_elem_info wlfw_soc_info_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_soc_info_s_v01, + soc_id), + }, + {} +}; + +static struct qmi_elem_info wlfw_fw_version_info_s_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_fw_version_info_s_v01, + fw_version), + }, + { + .data_type = QMI_STRING, + .elem_len = QMI_WLFW_MAX_TIMESTAMP_LEN_V01 + 1, + .elem_size = sizeof(char), + .array_type = NO_ARRAY, + .tlv_type = 0, + .offset = offsetof(struct wlfw_fw_version_info_s_v01, + fw_build_timestamp), + }, + {} +}; + +struct qmi_elem_info wlfw_ind_register_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + fw_ready_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + fw_ready_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + initiate_cal_download_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + initiate_cal_download_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + initiate_cal_update_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + initiate_cal_update_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + msa_ready_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + msa_ready_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + pin_connect_result_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + pin_connect_result_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + client_id_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + client_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x16, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + request_mem_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x16, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + request_mem_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x17, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + mem_ready_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x17, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + mem_ready_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x18, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + fw_init_done_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x18, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + fw_init_done_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x19, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + rejuvenate_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x19, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + rejuvenate_enable), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x1A, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + xo_cal_enable_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x1A, + .offset = offsetof(struct wlfw_ind_register_req_msg_v01, + xo_cal_enable), + }, + {} +}; + +struct qmi_elem_info wlfw_ind_register_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, + fw_status_valid), + }, + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ind_register_resp_msg_v01, + fw_status), + }, + {} +}; + +struct qmi_elem_info wlfw_fw_ready_ind_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_msa_ready_ind_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_pin_connect_result_ind_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + pwr_pin_result_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + pwr_pin_result), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + phy_io_pin_result_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + phy_io_pin_result), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + rf_pin_result_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_pin_connect_result_ind_msg_v01, + rf_pin_result), + }, + {} +}; + +struct qmi_elem_info wlfw_wlan_mode_req_msg_v01_ei[] = { + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_driver_mode_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, + mode), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, + hw_debug_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_wlan_mode_req_msg_v01, + hw_debug), + }, + {} +}; + +struct qmi_elem_info wlfw_wlan_mode_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_wlan_mode_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_wlan_cfg_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + host_version_valid), + }, + { + .data_type = QMI_STRING, + .elem_len = QMI_WLFW_MAX_STR_LEN_V01 + 1, + .elem_size = sizeof(char), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + host_version), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + tgt_cfg_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + tgt_cfg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_CE_V01, + .elem_size = sizeof(struct wlfw_ce_tgt_pipe_cfg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + tgt_cfg), + .ei_array = wlfw_ce_tgt_pipe_cfg_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + svc_cfg_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + svc_cfg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_SVC_V01, + .elem_size = sizeof(struct wlfw_ce_svc_pipe_cfg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + svc_cfg), + .ei_array = wlfw_ce_svc_pipe_cfg_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_SHADOW_REG_V01, + .elem_size = sizeof(struct wlfw_shadow_reg_cfg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg), + .ei_array = wlfw_shadow_reg_cfg_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg_v2_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg_v2_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_SHADOW_REG_V2, + .elem_size = sizeof(struct wlfw_shadow_reg_v2_cfg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_wlan_cfg_req_msg_v01, + shadow_reg_v2), + .ei_array = wlfw_shadow_reg_v2_cfg_s_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_wlan_cfg_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_wlan_cfg_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_cap_req_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + chip_info_valid), + }, + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct wlfw_rf_chip_info_s_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + chip_info), + .ei_array = wlfw_rf_chip_info_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + board_info_valid), + }, + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct wlfw_rf_board_info_s_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + board_info), + .ei_array = wlfw_rf_board_info_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + soc_info_valid), + }, + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct wlfw_soc_info_s_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + soc_info), + .ei_array = wlfw_soc_info_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + fw_version_info_valid), + }, + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct wlfw_fw_version_info_s_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + fw_version_info), + .ei_array = wlfw_fw_version_info_s_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + fw_build_id_valid), + }, + { + .data_type = QMI_STRING, + .elem_len = QMI_WLFW_MAX_BUILD_ID_LEN_V01 + 1, + .elem_size = sizeof(char), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + fw_build_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + num_macs_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_cap_resp_msg_v01, + num_macs), + }, + {} +}; + +struct qmi_elem_info wlfw_bdf_download_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + valid), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + file_id_valid), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + file_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + total_size_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + total_size), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + seg_id_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + seg_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + data_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + data_len), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + data), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + end_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + end), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + bdf_type_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x15, + .offset = offsetof(struct wlfw_bdf_download_req_msg_v01, + bdf_type), + }, + {} +}; + +struct qmi_elem_info wlfw_bdf_download_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_bdf_download_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_cal_report_req_msg_v01_ei[] = { + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, + meta_data_len), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = QMI_WLFW_MAX_NUM_CAL_V01, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, + meta_data), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, + xo_cal_data_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_report_req_msg_v01, + xo_cal_data), + }, + {} +}; + +struct qmi_elem_info wlfw_cal_report_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_cal_report_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_initiate_cal_download_ind_msg_v01_ei[] = { + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_initiate_cal_download_ind_msg_v01, + cal_id), + }, + {} +}; + +struct qmi_elem_info wlfw_cal_download_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + valid), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + file_id_valid), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + file_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + total_size_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + total_size), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + seg_id_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + seg_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + data_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + data_len), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + data), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + end_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cal_download_req_msg_v01, + end), + }, + {} +}; + +struct qmi_elem_info wlfw_cal_download_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_cal_download_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_initiate_cal_update_ind_msg_v01_ei[] = { + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_initiate_cal_update_ind_msg_v01, + cal_id), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_initiate_cal_update_ind_msg_v01, + total_size), + }, + {} +}; + +struct qmi_elem_info wlfw_cal_update_req_msg_v01_ei[] = { + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_cal_update_req_msg_v01, + cal_id), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_cal_update_req_msg_v01, + seg_id), + }, + {} +}; + +struct qmi_elem_info wlfw_cal_update_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + file_id_valid), + }, + { + .data_type = QMI_SIGNED_4_BYTE_ENUM, + .elem_len = 1, + .elem_size = sizeof(enum wlfw_cal_temp_id_enum_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + file_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + total_size_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + total_size), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + seg_id_valid), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + seg_id), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + data_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + data_len), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAX_DATA_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + data), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + end_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x14, + .offset = offsetof(struct wlfw_cal_update_resp_msg_v01, + end), + }, + {} +}; + +struct qmi_elem_info wlfw_msa_info_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_msa_info_req_msg_v01, + msa_addr), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_msa_info_req_msg_v01, + size), + }, + {} +}; + +struct qmi_elem_info wlfw_msa_info_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x03, + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, + mem_region_info_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_MEM_REG_V01, + .elem_size = sizeof(struct wlfw_memory_region_info_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x03, + .offset = offsetof(struct wlfw_msa_info_resp_msg_v01, + mem_region_info), + .ei_array = wlfw_memory_region_info_s_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_msa_ready_req_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_msa_ready_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_msa_ready_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_ini_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ini_req_msg_v01, + enablefwlog_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_ini_req_msg_v01, + enablefwlog), + }, + {} +}; + +struct qmi_elem_info wlfw_ini_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_ini_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_athdiag_read_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, + offset), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, + mem_type), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x03, + .offset = offsetof(struct wlfw_athdiag_read_req_msg_v01, + data_len), + }, + {} +}; + +struct qmi_elem_info wlfw_athdiag_read_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, + data_valid), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, + data_len), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_athdiag_read_resp_msg_v01, + data), + }, + {} +}; + +struct qmi_elem_info wlfw_athdiag_write_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, + offset), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, + mem_type), + }, + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x03, + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, + data_len), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x03, + .offset = offsetof(struct wlfw_athdiag_write_req_msg_v01, + data), + }, + {} +}; + +struct qmi_elem_info wlfw_athdiag_write_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_athdiag_write_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_vbatt_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_vbatt_req_msg_v01, + voltage_uv), + }, + {} +}; + +struct qmi_elem_info wlfw_vbatt_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_vbatt_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_mac_addr_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_mac_addr_req_msg_v01, + mac_addr_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = QMI_WLFW_MAC_ADDR_SIZE_V01, + .elem_size = sizeof(u8), + .array_type = STATIC_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_mac_addr_req_msg_v01, + mac_addr), + }, + {} +}; + +struct qmi_elem_info wlfw_mac_addr_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_mac_addr_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_host_cap_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_host_cap_req_msg_v01, + daemon_support_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_host_cap_req_msg_v01, + daemon_support), + }, + {} +}; + +struct qmi_elem_info wlfw_host_cap_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_host_cap_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_request_mem_ind_msg_v01_ei[] = { + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_request_mem_ind_msg_v01, + mem_seg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_MEM_SEG_V01, + .elem_size = sizeof(struct wlfw_mem_seg_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_request_mem_ind_msg_v01, + mem_seg), + .ei_array = wlfw_mem_seg_s_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_respond_mem_req_msg_v01_ei[] = { + { + .data_type = QMI_DATA_LEN, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_respond_mem_req_msg_v01, + mem_seg_len), + }, + { + .data_type = QMI_STRUCT, + .elem_len = QMI_WLFW_MAX_NUM_MEM_SEG_V01, + .elem_size = sizeof(struct wlfw_mem_seg_resp_s_v01), + .array_type = VAR_LEN_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_respond_mem_req_msg_v01, + mem_seg), + .ei_array = wlfw_mem_seg_resp_s_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_respond_mem_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_respond_mem_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_mem_ready_ind_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_fw_init_done_ind_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_rejuvenate_ind_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + cause_for_rejuvenation_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + cause_for_rejuvenation), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + requesting_sub_system_valid), + }, + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + requesting_sub_system), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + line_number_valid), + }, + { + .data_type = QMI_UNSIGNED_2_BYTE, + .elem_len = 1, + .elem_size = sizeof(u16), + .array_type = NO_ARRAY, + .tlv_type = 0x12, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + line_number), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + function_name_valid), + }, + { + .data_type = QMI_STRING, + .elem_len = QMI_WLFW_FUNCTION_NAME_LEN_V01 + 1, + .elem_size = sizeof(char), + .array_type = NO_ARRAY, + .tlv_type = 0x13, + .offset = offsetof(struct wlfw_rejuvenate_ind_msg_v01, + function_name), + }, + {} +}; + +struct qmi_elem_info wlfw_rejuvenate_ack_req_msg_v01_ei[] = { + {} +}; + +struct qmi_elem_info wlfw_rejuvenate_ack_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_rejuvenate_ack_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_dynamic_feature_mask_req_msg_v01_ei[] = { + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_dynamic_feature_mask_req_msg_v01, + mask_valid), + }, + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_dynamic_feature_mask_req_msg_v01, + mask), + }, + {} +}; + +struct qmi_elem_info wlfw_dynamic_feature_mask_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, + prev_mask_valid), + }, + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x10, + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, + prev_mask), + }, + { + .data_type = QMI_OPT_FLAG, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, + curr_mask_valid), + }, + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x11, + .offset = offsetof(struct wlfw_dynamic_feature_mask_resp_msg_v01, + curr_mask), + }, + {} +}; + +struct qmi_elem_info wlfw_m3_info_req_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_8_BYTE, + .elem_len = 1, + .elem_size = sizeof(u64), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_m3_info_req_msg_v01, + addr), + }, + { + .data_type = QMI_UNSIGNED_4_BYTE, + .elem_len = 1, + .elem_size = sizeof(u32), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_m3_info_req_msg_v01, + size), + }, + {} +}; + +struct qmi_elem_info wlfw_m3_info_resp_msg_v01_ei[] = { + { + .data_type = QMI_STRUCT, + .elem_len = 1, + .elem_size = sizeof(struct qmi_response_type_v01), + .array_type = NO_ARRAY, + .tlv_type = 0x02, + .offset = offsetof(struct wlfw_m3_info_resp_msg_v01, + resp), + .ei_array = qmi_response_type_v01_ei, + }, + {} +}; + +struct qmi_elem_info wlfw_xo_cal_ind_msg_v01_ei[] = { + { + .data_type = QMI_UNSIGNED_1_BYTE, + .elem_len = 1, + .elem_size = sizeof(u8), + .array_type = NO_ARRAY, + .tlv_type = 0x01, + .offset = offsetof(struct wlfw_xo_cal_ind_msg_v01, + xo_cal_data), + }, + {} +}; diff --git a/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h new file mode 100644 index 000000000000..c5e3870b8871 --- /dev/null +++ b/drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h @@ -0,0 +1,677 @@ +/* + * Copyright (c) 2018 The Linux Foundation. All rights reserved. + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +#ifndef WCN3990_QMI_SVC_V01_H +#define WCN3990_QMI_SVC_V01_H + +#define WLFW_SERVICE_ID_V01 0x45 +#define WLFW_SERVICE_VERS_V01 0x01 + +#define QMI_WLFW_BDF_DOWNLOAD_REQ_V01 0x0025 +#define QMI_WLFW_MEM_READY_IND_V01 0x0037 +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_RESP_V01 0x003B +#define QMI_WLFW_INITIATE_CAL_UPDATE_IND_V01 0x002A +#define QMI_WLFW_HOST_CAP_REQ_V01 0x0034 +#define QMI_WLFW_M3_INFO_REQ_V01 0x003C +#define QMI_WLFW_CAP_REQ_V01 0x0024 +#define QMI_WLFW_FW_INIT_DONE_IND_V01 0x0038 +#define QMI_WLFW_CAL_REPORT_REQ_V01 0x0026 +#define QMI_WLFW_M3_INFO_RESP_V01 0x003C +#define QMI_WLFW_CAL_UPDATE_RESP_V01 0x0029 +#define QMI_WLFW_CAL_DOWNLOAD_RESP_V01 0x0027 +#define QMI_WLFW_XO_CAL_IND_V01 0x003D +#define QMI_WLFW_INI_RESP_V01 0x002F +#define QMI_WLFW_CAL_REPORT_RESP_V01 0x0026 +#define QMI_WLFW_MAC_ADDR_RESP_V01 0x0033 +#define QMI_WLFW_INITIATE_CAL_DOWNLOAD_IND_V01 0x0028 +#define QMI_WLFW_HOST_CAP_RESP_V01 0x0034 +#define QMI_WLFW_MSA_READY_IND_V01 0x002B +#define QMI_WLFW_ATHDIAG_WRITE_RESP_V01 0x0031 +#define QMI_WLFW_WLAN_MODE_REQ_V01 0x0022 +#define QMI_WLFW_IND_REGISTER_REQ_V01 0x0020 +#define QMI_WLFW_WLAN_CFG_RESP_V01 0x0023 +#define QMI_WLFW_REQUEST_MEM_IND_V01 0x0035 +#define QMI_WLFW_REJUVENATE_IND_V01 0x0039 +#define QMI_WLFW_DYNAMIC_FEATURE_MASK_REQ_V01 0x003B +#define QMI_WLFW_ATHDIAG_WRITE_REQ_V01 0x0031 +#define QMI_WLFW_WLAN_MODE_RESP_V01 0x0022 +#define QMI_WLFW_RESPOND_MEM_REQ_V01 0x0036 +#define QMI_WLFW_PIN_CONNECT_RESULT_IND_V01 0x002C +#define QMI_WLFW_FW_READY_IND_V01 0x0021 +#define QMI_WLFW_MSA_READY_RESP_V01 0x002E +#define QMI_WLFW_CAL_UPDATE_REQ_V01 0x0029 +#define QMI_WLFW_INI_REQ_V01 0x002F +#define QMI_WLFW_BDF_DOWNLOAD_RESP_V01 0x0025 +#define QMI_WLFW_REJUVENATE_ACK_RESP_V01 0x003A +#define QMI_WLFW_MSA_INFO_RESP_V01 0x002D +#define QMI_WLFW_MSA_READY_REQ_V01 0x002E +#define QMI_WLFW_CAP_RESP_V01 0x0024 +#define QMI_WLFW_REJUVENATE_ACK_REQ_V01 0x003A +#define QMI_WLFW_ATHDIAG_READ_RESP_V01 0x0030 +#define QMI_WLFW_VBATT_REQ_V01 0x0032 +#define QMI_WLFW_MAC_ADDR_REQ_V01 0x0033 +#define QMI_WLFW_RESPOND_MEM_RESP_V01 0x0036 +#define QMI_WLFW_VBATT_RESP_V01 0x0032 +#define QMI_WLFW_MSA_INFO_REQ_V01 0x002D +#define QMI_WLFW_CAL_DOWNLOAD_REQ_V01 0x0027 +#define QMI_WLFW_ATHDIAG_READ_REQ_V01 0x0030 +#define QMI_WLFW_WLAN_CFG_REQ_V01 0x0023 +#define QMI_WLFW_IND_REGISTER_RESP_V01 0x0020 + +#define QMI_WLFW_MAX_MEM_REG_V01 2 +#define QMI_WLFW_MAX_NUM_MEM_SEG_V01 16 +#define QMI_WLFW_MAX_NUM_CAL_V01 5 +#define QMI_WLFW_MAX_DATA_SIZE_V01 6144 +#define QMI_WLFW_FUNCTION_NAME_LEN_V01 128 +#define QMI_WLFW_MAX_NUM_CE_V01 12 +#define QMI_WLFW_MAX_TIMESTAMP_LEN_V01 32 +#define QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01 6144 +#define QMI_WLFW_MAX_NUM_GPIO_V01 32 +#define QMI_WLFW_MAX_BUILD_ID_LEN_V01 128 +#define QMI_WLFW_MAX_NUM_MEM_CFG_V01 2 +#define QMI_WLFW_MAX_STR_LEN_V01 16 +#define QMI_WLFW_MAX_NUM_SHADOW_REG_V01 24 +#define QMI_WLFW_MAC_ADDR_SIZE_V01 6 +#define QMI_WLFW_MAX_SHADOW_REG_V2 36 +#define QMI_WLFW_MAX_NUM_SVC_V01 24 + +enum wlfw_driver_mode_enum_v01 { + QMI_WLFW_MISSION_V01 = 0, + QMI_WLFW_FTM_V01 = 1, + QMI_WLFW_EPPING_V01 = 2, + QMI_WLFW_WALTEST_V01 = 3, + QMI_WLFW_OFF_V01 = 4, + QMI_WLFW_CCPM_V01 = 5, + QMI_WLFW_QVIT_V01 = 6, + QMI_WLFW_CALIBRATION_V01 = 7, +}; + +enum wlfw_cal_temp_id_enum_v01 { + QMI_WLFW_CAL_TEMP_IDX_0_V01 = 0, + QMI_WLFW_CAL_TEMP_IDX_1_V01 = 1, + QMI_WLFW_CAL_TEMP_IDX_2_V01 = 2, + QMI_WLFW_CAL_TEMP_IDX_3_V01 = 3, + QMI_WLFW_CAL_TEMP_IDX_4_V01 = 4, +}; + +enum wlfw_pipedir_enum_v01 { + QMI_WLFW_PIPEDIR_NONE_V01 = 0, + QMI_WLFW_PIPEDIR_IN_V01 = 1, + QMI_WLFW_PIPEDIR_OUT_V01 = 2, + QMI_WLFW_PIPEDIR_INOUT_V01 = 3, +}; + +enum wlfw_mem_type_enum_v01 { + QMI_WLFW_MEM_TYPE_MSA_V01 = 0, + QMI_WLFW_MEM_TYPE_DDR_V01 = 1, +}; + +#define QMI_WLFW_CE_ATTR_FLAGS_V01 ((u32)0x00) +#define QMI_WLFW_CE_ATTR_NO_SNOOP_V01 ((u32)0x01) +#define QMI_WLFW_CE_ATTR_BYTE_SWAP_DATA_V01 ((u32)0x02) +#define QMI_WLFW_CE_ATTR_SWIZZLE_DESCRIPTORS_V01 ((u32)0x04) +#define QMI_WLFW_CE_ATTR_DISABLE_INTR_V01 ((u32)0x08) +#define QMI_WLFW_CE_ATTR_ENABLE_POLL_V01 ((u32)0x10) + +#define QMI_WLFW_ALREADY_REGISTERED_V01 ((u64)0x01ULL) +#define QMI_WLFW_FW_READY_V01 ((u64)0x02ULL) +#define QMI_WLFW_MSA_READY_V01 ((u64)0x04ULL) +#define QMI_WLFW_MEM_READY_V01 ((u64)0x08ULL) +#define QMI_WLFW_FW_INIT_DONE_V01 ((u64)0x10ULL) + +#define QMI_WLFW_FW_REJUVENATE_V01 ((u64)0x01ULL) + +struct wlfw_ce_tgt_pipe_cfg_s_v01 { + __le32 pipe_num; + __le32 pipe_dir; + __le32 nentries; + __le32 nbytes_max; + __le32 flags; +}; + +struct wlfw_ce_svc_pipe_cfg_s_v01 { + __le32 service_id; + __le32 pipe_dir; + __le32 pipe_num; +}; + +struct wlfw_shadow_reg_cfg_s_v01 { + u16 id; + u16 offset; +}; + +struct wlfw_shadow_reg_v2_cfg_s_v01 { + u32 addr; +}; + +struct wlfw_memory_region_info_s_v01 { + u64 region_addr; + u32 size; + u8 secure_flag; +}; + +struct wlfw_mem_cfg_s_v01 { + u64 offset; + u32 size; + u8 secure_flag; +}; + +struct wlfw_mem_seg_s_v01 { + u32 size; + enum wlfw_mem_type_enum_v01 type; + u32 mem_cfg_len; + struct wlfw_mem_cfg_s_v01 mem_cfg[QMI_WLFW_MAX_NUM_MEM_CFG_V01]; +}; + +struct wlfw_mem_seg_resp_s_v01 { + u64 addr; + u32 size; + enum wlfw_mem_type_enum_v01 type; +}; + +struct wlfw_rf_chip_info_s_v01 { + u32 chip_id; + u32 chip_family; +}; + +struct wlfw_rf_board_info_s_v01 { + u32 board_id; +}; + +struct wlfw_soc_info_s_v01 { + u32 soc_id; +}; + +struct wlfw_fw_version_info_s_v01 { + u32 fw_version; + char fw_build_timestamp[QMI_WLFW_MAX_TIMESTAMP_LEN_V01 + 1]; +}; + +struct wlfw_ind_register_req_msg_v01 { + u8 fw_ready_enable_valid; + u8 fw_ready_enable; + u8 initiate_cal_download_enable_valid; + u8 initiate_cal_download_enable; + u8 initiate_cal_update_enable_valid; + u8 initiate_cal_update_enable; + u8 msa_ready_enable_valid; + u8 msa_ready_enable; + u8 pin_connect_result_enable_valid; + u8 pin_connect_result_enable; + u8 client_id_valid; + u32 client_id; + u8 request_mem_enable_valid; + u8 request_mem_enable; + u8 mem_ready_enable_valid; + u8 mem_ready_enable; + u8 fw_init_done_enable_valid; + u8 fw_init_done_enable; + u8 rejuvenate_enable_valid; + u32 rejuvenate_enable; + u8 xo_cal_enable_valid; + u8 xo_cal_enable; +}; + +#define WLFW_IND_REGISTER_REQ_MSG_V01_MAX_MSG_LEN 50 +extern struct qmi_elem_info wlfw_ind_register_req_msg_v01_ei[]; + +struct wlfw_ind_register_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u8 fw_status_valid; + u64 fw_status; +}; + +#define WLFW_IND_REGISTER_RESP_MSG_V01_MAX_MSG_LEN 18 +extern struct qmi_elem_info wlfw_ind_register_resp_msg_v01_ei[]; + +struct wlfw_fw_ready_ind_msg_v01 { + char placeholder; +}; + +#define WLFW_FW_READY_IND_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_fw_ready_ind_msg_v01_ei[]; + +struct wlfw_msa_ready_ind_msg_v01 { + char placeholder; +}; + +#define WLFW_MSA_READY_IND_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_msa_ready_ind_msg_v01_ei[]; + +struct wlfw_pin_connect_result_ind_msg_v01 { + u8 pwr_pin_result_valid; + u32 pwr_pin_result; + u8 phy_io_pin_result_valid; + u32 phy_io_pin_result; + u8 rf_pin_result_valid; + u32 rf_pin_result; +}; + +#define WLFW_PIN_CONNECT_RESULT_IND_MSG_V01_MAX_MSG_LEN 21 +extern struct qmi_elem_info wlfw_pin_connect_result_ind_msg_v01_ei[]; + +struct wlfw_wlan_mode_req_msg_v01 { + enum wlfw_driver_mode_enum_v01 mode; + u8 hw_debug_valid; + u8 hw_debug; +}; + +#define WLFW_WLAN_MODE_REQ_MSG_V01_MAX_MSG_LEN 11 +extern struct qmi_elem_info wlfw_wlan_mode_req_msg_v01_ei[]; + +struct wlfw_wlan_mode_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_WLAN_MODE_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_wlan_mode_resp_msg_v01_ei[]; + +struct wlfw_wlan_cfg_req_msg_v01 { + u8 host_version_valid; + char host_version[QMI_WLFW_MAX_STR_LEN_V01 + 1]; + u8 tgt_cfg_valid; + u32 tgt_cfg_len; + struct wlfw_ce_tgt_pipe_cfg_s_v01 tgt_cfg[QMI_WLFW_MAX_NUM_CE_V01]; + u8 svc_cfg_valid; + u32 svc_cfg_len; + struct wlfw_ce_svc_pipe_cfg_s_v01 svc_cfg[QMI_WLFW_MAX_NUM_SVC_V01]; + u8 shadow_reg_valid; + u32 shadow_reg_len; + struct wlfw_shadow_reg_cfg_s_v01 shadow_reg[QMI_WLFW_MAX_NUM_SHADOW_REG_V01]; + u8 shadow_reg_v2_valid; + u32 shadow_reg_v2_len; + struct wlfw_shadow_reg_v2_cfg_s_v01 shadow_reg_v2[QMI_WLFW_MAX_SHADOW_REG_V2]; +}; + +#define WLFW_WLAN_CFG_REQ_MSG_V01_MAX_MSG_LEN 803 +extern struct qmi_elem_info wlfw_wlan_cfg_req_msg_v01_ei[]; + +struct wlfw_wlan_cfg_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_WLAN_CFG_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_wlan_cfg_resp_msg_v01_ei[]; + +struct wlfw_cap_req_msg_v01 { + char placeholder; +}; + +#define WLFW_CAP_REQ_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_cap_req_msg_v01_ei[]; + +struct wlfw_cap_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u8 chip_info_valid; + struct wlfw_rf_chip_info_s_v01 chip_info; + u8 board_info_valid; + struct wlfw_rf_board_info_s_v01 board_info; + u8 soc_info_valid; + struct wlfw_soc_info_s_v01 soc_info; + u8 fw_version_info_valid; + struct wlfw_fw_version_info_s_v01 fw_version_info; + u8 fw_build_id_valid; + char fw_build_id[QMI_WLFW_MAX_BUILD_ID_LEN_V01 + 1]; + u8 num_macs_valid; + u8 num_macs; +}; + +#define WLFW_CAP_RESP_MSG_V01_MAX_MSG_LEN 207 +extern struct qmi_elem_info wlfw_cap_resp_msg_v01_ei[]; + +struct wlfw_bdf_download_req_msg_v01 { + u8 valid; + u8 file_id_valid; + enum wlfw_cal_temp_id_enum_v01 file_id; + u8 total_size_valid; + u32 total_size; + u8 seg_id_valid; + u32 seg_id; + u8 data_valid; + u32 data_len; + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; + u8 end_valid; + u8 end; + u8 bdf_type_valid; + u8 bdf_type; +}; + +#define WLFW_BDF_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6182 +extern struct qmi_elem_info wlfw_bdf_download_req_msg_v01_ei[]; + +struct wlfw_bdf_download_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_BDF_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_bdf_download_resp_msg_v01_ei[]; + +struct wlfw_cal_report_req_msg_v01 { + u32 meta_data_len; + enum wlfw_cal_temp_id_enum_v01 meta_data[QMI_WLFW_MAX_NUM_CAL_V01]; + u8 xo_cal_data_valid; + u8 xo_cal_data; +}; + +#define WLFW_CAL_REPORT_REQ_MSG_V01_MAX_MSG_LEN 28 +extern struct qmi_elem_info wlfw_cal_report_req_msg_v01_ei[]; + +struct wlfw_cal_report_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_CAL_REPORT_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_cal_report_resp_msg_v01_ei[]; + +struct wlfw_initiate_cal_download_ind_msg_v01 { + enum wlfw_cal_temp_id_enum_v01 cal_id; +}; + +#define WLFW_INITIATE_CAL_DOWNLOAD_IND_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_initiate_cal_download_ind_msg_v01_ei[]; + +struct wlfw_cal_download_req_msg_v01 { + u8 valid; + u8 file_id_valid; + enum wlfw_cal_temp_id_enum_v01 file_id; + u8 total_size_valid; + u32 total_size; + u8 seg_id_valid; + u32 seg_id; + u8 data_valid; + u32 data_len; + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; + u8 end_valid; + u8 end; +}; + +#define WLFW_CAL_DOWNLOAD_REQ_MSG_V01_MAX_MSG_LEN 6178 +extern struct qmi_elem_info wlfw_cal_download_req_msg_v01_ei[]; + +struct wlfw_cal_download_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_CAL_DOWNLOAD_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_cal_download_resp_msg_v01_ei[]; + +struct wlfw_initiate_cal_update_ind_msg_v01 { + enum wlfw_cal_temp_id_enum_v01 cal_id; + u32 total_size; +}; + +#define WLFW_INITIATE_CAL_UPDATE_IND_MSG_V01_MAX_MSG_LEN 14 +extern struct qmi_elem_info wlfw_initiate_cal_update_ind_msg_v01_ei[]; + +struct wlfw_cal_update_req_msg_v01 { + enum wlfw_cal_temp_id_enum_v01 cal_id; + u32 seg_id; +}; + +#define WLFW_CAL_UPDATE_REQ_MSG_V01_MAX_MSG_LEN 14 +extern struct qmi_elem_info wlfw_cal_update_req_msg_v01_ei[]; + +struct wlfw_cal_update_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u8 file_id_valid; + enum wlfw_cal_temp_id_enum_v01 file_id; + u8 total_size_valid; + u32 total_size; + u8 seg_id_valid; + u32 seg_id; + u8 data_valid; + u32 data_len; + u8 data[QMI_WLFW_MAX_DATA_SIZE_V01]; + u8 end_valid; + u8 end; +}; + +#define WLFW_CAL_UPDATE_RESP_MSG_V01_MAX_MSG_LEN 6181 +extern struct qmi_elem_info wlfw_cal_update_resp_msg_v01_ei[]; + +struct wlfw_msa_info_req_msg_v01 { + u64 msa_addr; + u32 size; +}; + +#define WLFW_MSA_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 +extern struct qmi_elem_info wlfw_msa_info_req_msg_v01_ei[]; + +struct wlfw_msa_info_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u32 mem_region_info_len; + struct wlfw_memory_region_info_s_v01 mem_region_info[QMI_WLFW_MAX_MEM_REG_V01]; +}; + +#define WLFW_MSA_INFO_RESP_MSG_V01_MAX_MSG_LEN 37 +extern struct qmi_elem_info wlfw_msa_info_resp_msg_v01_ei[]; + +struct wlfw_msa_ready_req_msg_v01 { + char placeholder; +}; + +#define WLFW_MSA_READY_REQ_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_msa_ready_req_msg_v01_ei[]; + +struct wlfw_msa_ready_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_MSA_READY_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_msa_ready_resp_msg_v01_ei[]; + +struct wlfw_ini_req_msg_v01 { + u8 enablefwlog_valid; + u8 enablefwlog; +}; + +#define WLFW_INI_REQ_MSG_V01_MAX_MSG_LEN 4 +extern struct qmi_elem_info wlfw_ini_req_msg_v01_ei[]; + +struct wlfw_ini_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_INI_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_ini_resp_msg_v01_ei[]; + +struct wlfw_athdiag_read_req_msg_v01 { + u32 offset; + u32 mem_type; + u32 data_len; +}; + +#define WLFW_ATHDIAG_READ_REQ_MSG_V01_MAX_MSG_LEN 21 +extern struct qmi_elem_info wlfw_athdiag_read_req_msg_v01_ei[]; + +struct wlfw_athdiag_read_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u8 data_valid; + u32 data_len; + u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; +}; + +#define WLFW_ATHDIAG_READ_RESP_MSG_V01_MAX_MSG_LEN 6156 +extern struct qmi_elem_info wlfw_athdiag_read_resp_msg_v01_ei[]; + +struct wlfw_athdiag_write_req_msg_v01 { + u32 offset; + u32 mem_type; + u32 data_len; + u8 data[QMI_WLFW_MAX_ATHDIAG_DATA_SIZE_V01]; +}; + +#define WLFW_ATHDIAG_WRITE_REQ_MSG_V01_MAX_MSG_LEN 6163 +extern struct qmi_elem_info wlfw_athdiag_write_req_msg_v01_ei[]; + +struct wlfw_athdiag_write_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_ATHDIAG_WRITE_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_athdiag_write_resp_msg_v01_ei[]; + +struct wlfw_vbatt_req_msg_v01 { + u64 voltage_uv; +}; + +#define WLFW_VBATT_REQ_MSG_V01_MAX_MSG_LEN 11 +extern struct qmi_elem_info wlfw_vbatt_req_msg_v01_ei[]; + +struct wlfw_vbatt_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_VBATT_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_vbatt_resp_msg_v01_ei[]; + +struct wlfw_mac_addr_req_msg_v01 { + u8 mac_addr_valid; + u8 mac_addr[QMI_WLFW_MAC_ADDR_SIZE_V01]; +}; + +#define WLFW_MAC_ADDR_REQ_MSG_V01_MAX_MSG_LEN 9 +extern struct qmi_elem_info wlfw_mac_addr_req_msg_v01_ei[]; + +struct wlfw_mac_addr_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_MAC_ADDR_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_mac_addr_resp_msg_v01_ei[]; + +struct wlfw_host_cap_req_msg_v01 { + u8 daemon_support_valid; + u8 daemon_support; +}; + +#define WLFW_HOST_CAP_REQ_MSG_V01_MAX_MSG_LEN 4 +extern struct qmi_elem_info wlfw_host_cap_req_msg_v01_ei[]; + +struct wlfw_host_cap_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_HOST_CAP_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_host_cap_resp_msg_v01_ei[]; + +struct wlfw_request_mem_ind_msg_v01 { + u32 mem_seg_len; + struct wlfw_mem_seg_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; +}; + +#define WLFW_REQUEST_MEM_IND_MSG_V01_MAX_MSG_LEN 564 +extern struct qmi_elem_info wlfw_request_mem_ind_msg_v01_ei[]; + +struct wlfw_respond_mem_req_msg_v01 { + u32 mem_seg_len; + struct wlfw_mem_seg_resp_s_v01 mem_seg[QMI_WLFW_MAX_NUM_MEM_SEG_V01]; +}; + +#define WLFW_RESPOND_MEM_REQ_MSG_V01_MAX_MSG_LEN 260 +extern struct qmi_elem_info wlfw_respond_mem_req_msg_v01_ei[]; + +struct wlfw_respond_mem_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_RESPOND_MEM_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_respond_mem_resp_msg_v01_ei[]; + +struct wlfw_mem_ready_ind_msg_v01 { + char placeholder; +}; + +#define WLFW_MEM_READY_IND_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_mem_ready_ind_msg_v01_ei[]; + +struct wlfw_fw_init_done_ind_msg_v01 { + char placeholder; +}; + +#define WLFW_FW_INIT_DONE_IND_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_fw_init_done_ind_msg_v01_ei[]; + +struct wlfw_rejuvenate_ind_msg_v01 { + u8 cause_for_rejuvenation_valid; + u8 cause_for_rejuvenation; + u8 requesting_sub_system_valid; + u8 requesting_sub_system; + u8 line_number_valid; + u16 line_number; + u8 function_name_valid; + char function_name[QMI_WLFW_FUNCTION_NAME_LEN_V01 + 1]; +}; + +#define WLFW_REJUVENATE_IND_MSG_V01_MAX_MSG_LEN 144 +extern struct qmi_elem_info wlfw_rejuvenate_ind_msg_v01_ei[]; + +struct wlfw_rejuvenate_ack_req_msg_v01 { + char placeholder; +}; + +#define WLFW_REJUVENATE_ACK_REQ_MSG_V01_MAX_MSG_LEN 0 +extern struct qmi_elem_info wlfw_rejuvenate_ack_req_msg_v01_ei[]; + +struct wlfw_rejuvenate_ack_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_REJUVENATE_ACK_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_rejuvenate_ack_resp_msg_v01_ei[]; + +struct wlfw_dynamic_feature_mask_req_msg_v01 { + u8 mask_valid; + u64 mask; +}; + +#define WLFW_DYNAMIC_FEATURE_MASK_REQ_MSG_V01_MAX_MSG_LEN 11 +extern struct qmi_elem_info wlfw_dynamic_feature_mask_req_msg_v01_ei[]; + +struct wlfw_dynamic_feature_mask_resp_msg_v01 { + struct qmi_response_type_v01 resp; + u8 prev_mask_valid; + u64 prev_mask; + u8 curr_mask_valid; + u64 curr_mask; +}; + +#define WLFW_DYNAMIC_FEATURE_MASK_RESP_MSG_V01_MAX_MSG_LEN 29 +extern struct qmi_elem_info wlfw_dynamic_feature_mask_resp_msg_v01_ei[]; + +struct wlfw_m3_info_req_msg_v01 { + u64 addr; + u32 size; +}; + +#define WLFW_M3_INFO_REQ_MSG_V01_MAX_MSG_LEN 18 +extern struct qmi_elem_info wlfw_m3_info_req_msg_v01_ei[]; + +struct wlfw_m3_info_resp_msg_v01 { + struct qmi_response_type_v01 resp; +}; + +#define WLFW_M3_INFO_RESP_MSG_V01_MAX_MSG_LEN 7 +extern struct qmi_elem_info wlfw_m3_info_resp_msg_v01_ei[]; + +struct wlfw_xo_cal_ind_msg_v01 { + u8 xo_cal_data; +}; + +#define WLFW_XO_CAL_IND_MSG_V01_MAX_MSG_LEN 4 +extern struct qmi_elem_info wlfw_xo_cal_ind_msg_v01_ei[]; + +#endif
WLAN qmi server running in Q6 exposes host to target cold boot qmi handshakes. Add WLAN QMI service helpers for ath10k wcn3990 qmi client. Signed-off-by: Govind Singh <govinds@codeaurora.org> --- .../net/wireless/ath/ath10k/qmi_wlfw_v01.c | 2072 +++++++++++++++++ .../net/wireless/ath/ath10k/qmi_wlfw_v01.h | 677 ++++++ 2 files changed, 2749 insertions(+) create mode 100644 drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.c create mode 100644 drivers/net/wireless/ath/ath10k/qmi_wlfw_v01.h