From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.3 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_PASS,URIBL_BLOCKED,USER_AGENT_MUTT autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 80905C64EAD for ; Tue, 9 Oct 2018 06:29:02 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 0F04321479 for ; Tue, 9 Oct 2018 06:29:02 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=linaro.org header.i=@linaro.org header.b="Lph7X990" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 0F04321479 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=linaro.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-wireless-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726608AbeJINoU (ORCPT ); Tue, 9 Oct 2018 09:44:20 -0400 Received: from mail-pg1-f194.google.com ([209.85.215.194]:33403 "EHLO mail-pg1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726445AbeJINoU (ORCPT ); Tue, 9 Oct 2018 09:44:20 -0400 Received: by mail-pg1-f194.google.com with SMTP id y18-v6so305210pge.0 for ; Mon, 08 Oct 2018 23:28:58 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=AGc0kcA0cBRuy3VlRKYL5NmBUXAZLtnvOHf4wfy/tpw=; b=Lph7X990NoBHH4gdiB8uLZgG++9TxV0pi0pX2aLtdejEut25i4mqxma66ByD7/hZjO je0p10IAuPqjBD6I5PVIRIh6KIUcHd0A5FesqVSwFeYUuHOvZPMT6Zs1aONTcaUl2Peg 7qqCe9kkSwRpWq5q3e8IsEEOLQ39FhgZXb33M= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=AGc0kcA0cBRuy3VlRKYL5NmBUXAZLtnvOHf4wfy/tpw=; b=itySNZrltRqGlEhYxEkuQHGn+2X+WBBOhjGtOH2KrYFbborDrkHyXiqcdT3CKp9M2i hCnARgf2NPf5dRSUlxSy55O1k1qOZwhkMdCgOAsovq1AfJWznHA/5gxeu2W7Ji5en9Ub By5Sm+DitzYN8nKJgkNqSIIbitsVEUFgLnmo118vNMVPGxtIh82Q/dpTtaAYxSpMDfj8 JWrfhMGKphoaNeZtdeoRdQ453mD2OkUuAUNV58LUA/GvDQJb+AGnMNveHSy5s0bjgOnR McQ0NwNMLxQtpGfAXJJfUyn2zyJjZnq95tVexd49LjW6Fs7zIrxz/2Ynqc6pXSWHOul7 NgIw== X-Gm-Message-State: ABuFfojw+ggdbTZLrJa7+6Xfv0lBxMJyrjr1Rpn5Yq+9jcH12RTGv2G8 imYEvHr3KZ+3axDlGzgUCEktRg== X-Google-Smtp-Source: ACcGV61dv/qSNYHyBAJg4BxKh9SkQXMyMnzl7Dy7x/dmiYnhJ8+rEGmUlaQwpnL9YAc/Wcsh7Sm5SA== X-Received: by 2002:aa7:8598:: with SMTP id w24-v6mr29033204pfn.77.1539066537273; Mon, 08 Oct 2018 23:28:57 -0700 (PDT) Received: from tuxbook-pro (104-188-17-28.lightspeed.sndgca.sbcglobal.net. [104.188.17.28]) by smtp.gmail.com with ESMTPSA id d10-v6sm20091639pgp.26.2018.10.08.23.28.56 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 08 Oct 2018 23:28:56 -0700 (PDT) Date: Mon, 8 Oct 2018 23:28:54 -0700 From: Bjorn Andersson To: Govind Singh Cc: ath10k@lists.infradead.org, briannorris@chromium.org, niklas.cassel@linaro.org, andy.gross@linaro.org, devicetree@vger.kernel.org, linux-wireless@vger.kernel.org Subject: Re: [PATCH v5 1/6] ath10k: Add qmi service helpers for wcn3990 qmi client Message-ID: <20181009062854.GB8498@tuxbook-pro> References: <20180815092637.11455-1-govinds@codeaurora.org> <20180815092637.11455-2-govinds@codeaurora.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20180815092637.11455-2-govinds@codeaurora.org> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-wireless-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-wireless@vger.kernel.org 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 Regards, Bjorn > Signed-off-by: Govind Singh > --- > .../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 > +#include > +#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 > From mboxrd@z Thu Jan 1 00:00:00 1970 From: Bjorn Andersson Subject: Re: [PATCH v5 1/6] ath10k: Add qmi service helpers for wcn3990 qmi client Date: Mon, 8 Oct 2018 23:28:54 -0700 Message-ID: <20181009062854.GB8498@tuxbook-pro> References: <20180815092637.11455-1-govinds@codeaurora.org> <20180815092637.11455-2-govinds@codeaurora.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20180815092637.11455-2-govinds-sgV2jX0FEOL9JmXXK+q4OQ@public.gmane.org> Sender: linux-wireless-owner-u79uwXL29TY76Z2rM5mHXA@public.gmane.org To: Govind Singh Cc: ath10k-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org, briannorris-F7+t8E8rja9g9hUCZPvPmw@public.gmane.org, niklas.cassel-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org, andy.gross-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org, devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, linux-wireless-u79uwXL29TY76Z2rM5mHXA@public.gmane.org List-Id: devicetree@vger.kernel.org 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 Regards, Bjorn > Signed-off-by: Govind Singh > --- > .../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 > +#include > +#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 > From mboxrd@z Thu Jan 1 00:00:00 1970 Return-path: Received: from mail-pf1-x442.google.com ([2607:f8b0:4864:20::442]) by bombadil.infradead.org with esmtps (Exim 4.90_1 #2 (Red Hat Linux)) id 1g9lW0-0007A7-OD for ath10k@lists.infradead.org; Tue, 09 Oct 2018 06:29:14 +0000 Received: by mail-pf1-x442.google.com with SMTP id f29-v6so308803pff.5 for ; Mon, 08 Oct 2018 23:28:58 -0700 (PDT) Date: Mon, 8 Oct 2018 23:28:54 -0700 From: Bjorn Andersson Subject: Re: [PATCH v5 1/6] ath10k: Add qmi service helpers for wcn3990 qmi client Message-ID: <20181009062854.GB8498@tuxbook-pro> References: <20180815092637.11455-1-govinds@codeaurora.org> <20180815092637.11455-2-govinds@codeaurora.org> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20180815092637.11455-2-govinds@codeaurora.org> List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "ath10k" Errors-To: ath10k-bounces+kvalo=adurom.com@lists.infradead.org To: Govind Singh Cc: devicetree@vger.kernel.org, briannorris@chromium.org, linux-wireless@vger.kernel.org, ath10k@lists.infradead.org, andy.gross@linaro.org, niklas.cassel@linaro.org 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 Regards, Bjorn > Signed-off-by: Govind Singh > --- > .../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 > +#include > +#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 > _______________________________________________ ath10k mailing list ath10k@lists.infradead.org http://lists.infradead.org/mailman/listinfo/ath10k