1 // SPDX-License-Identifier: BSD-3-Clause-Clear
3 * Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.
4 * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
13 #include <linux/firmware.h>
15 #define SLEEP_CLOCK_SELECT_INTERNAL_BIT 0x02
16 #define HOST_CSTATE_BIT 0x04
17 #define PLATFORM_CAP_PCIE_GLOBAL_RESET 0x08
18 #define ATH12K_QMI_MAX_CHUNK_SIZE 2097152
20 static struct qmi_elem_info wlfw_host_mlo_chip_info_s_v01_ei[] = {
22 .data_type = QMI_UNSIGNED_1_BYTE,
24 .elem_size = sizeof(u8),
25 .array_type = NO_ARRAY,
27 .offset = offsetof(struct wlfw_host_mlo_chip_info_s_v01,
31 .data_type = QMI_UNSIGNED_1_BYTE,
33 .elem_size = sizeof(u8),
34 .array_type = NO_ARRAY,
36 .offset = offsetof(struct wlfw_host_mlo_chip_info_s_v01,
40 .data_type = QMI_UNSIGNED_1_BYTE,
41 .elem_len = QMI_WLFW_MAX_NUM_MLO_LINKS_PER_CHIP_V01,
42 .elem_size = sizeof(u8),
43 .array_type = STATIC_ARRAY,
45 .offset = offsetof(struct wlfw_host_mlo_chip_info_s_v01,
49 .data_type = QMI_UNSIGNED_1_BYTE,
50 .elem_len = QMI_WLFW_MAX_NUM_MLO_LINKS_PER_CHIP_V01,
51 .elem_size = sizeof(u8),
52 .array_type = STATIC_ARRAY,
54 .offset = offsetof(struct wlfw_host_mlo_chip_info_s_v01,
58 .data_type = QMI_EOTI,
59 .array_type = NO_ARRAY,
60 .tlv_type = QMI_COMMON_TLV_TYPE,
64 static struct qmi_elem_info qmi_wlanfw_host_cap_req_msg_v01_ei[] = {
66 .data_type = QMI_OPT_FLAG,
68 .elem_size = sizeof(u8),
69 .array_type = NO_ARRAY,
71 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
75 .data_type = QMI_UNSIGNED_4_BYTE,
77 .elem_size = sizeof(u32),
78 .array_type = NO_ARRAY,
80 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
84 .data_type = QMI_OPT_FLAG,
86 .elem_size = sizeof(u8),
87 .array_type = NO_ARRAY,
89 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
93 .data_type = QMI_UNSIGNED_4_BYTE,
95 .elem_size = sizeof(u32),
96 .array_type = NO_ARRAY,
98 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
102 .data_type = QMI_OPT_FLAG,
104 .elem_size = sizeof(u8),
105 .array_type = NO_ARRAY,
107 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
111 .data_type = QMI_DATA_LEN,
113 .elem_size = sizeof(u8),
114 .array_type = NO_ARRAY,
116 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
120 .data_type = QMI_UNSIGNED_4_BYTE,
121 .elem_len = QMI_WLFW_MAX_NUM_GPIO_V01,
122 .elem_size = sizeof(u32),
123 .array_type = VAR_LEN_ARRAY,
125 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
129 .data_type = QMI_OPT_FLAG,
131 .elem_size = sizeof(u8),
132 .array_type = NO_ARRAY,
134 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
138 .data_type = QMI_UNSIGNED_1_BYTE,
140 .elem_size = sizeof(u8),
141 .array_type = NO_ARRAY,
143 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
147 .data_type = QMI_OPT_FLAG,
149 .elem_size = sizeof(u8),
150 .array_type = NO_ARRAY,
152 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
156 .data_type = QMI_UNSIGNED_1_BYTE,
158 .elem_size = sizeof(u8),
159 .array_type = NO_ARRAY,
161 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
165 .data_type = QMI_OPT_FLAG,
167 .elem_size = sizeof(u8),
168 .array_type = NO_ARRAY,
170 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
171 bdf_cache_support_valid),
174 .data_type = QMI_UNSIGNED_1_BYTE,
176 .elem_size = sizeof(u8),
177 .array_type = NO_ARRAY,
179 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
183 .data_type = QMI_OPT_FLAG,
185 .elem_size = sizeof(u8),
186 .array_type = NO_ARRAY,
188 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
192 .data_type = QMI_UNSIGNED_1_BYTE,
194 .elem_size = sizeof(u8),
195 .array_type = NO_ARRAY,
197 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
201 .data_type = QMI_OPT_FLAG,
203 .elem_size = sizeof(u8),
204 .array_type = NO_ARRAY,
206 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
207 m3_cache_support_valid),
210 .data_type = QMI_UNSIGNED_1_BYTE,
212 .elem_size = sizeof(u8),
213 .array_type = NO_ARRAY,
215 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
219 .data_type = QMI_OPT_FLAG,
221 .elem_size = sizeof(u8),
222 .array_type = NO_ARRAY,
224 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
225 cal_filesys_support_valid),
228 .data_type = QMI_UNSIGNED_1_BYTE,
230 .elem_size = sizeof(u8),
231 .array_type = NO_ARRAY,
233 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
234 cal_filesys_support),
237 .data_type = QMI_OPT_FLAG,
239 .elem_size = sizeof(u8),
240 .array_type = NO_ARRAY,
242 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
243 cal_cache_support_valid),
246 .data_type = QMI_UNSIGNED_1_BYTE,
248 .elem_size = sizeof(u8),
249 .array_type = NO_ARRAY,
251 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
255 .data_type = QMI_OPT_FLAG,
257 .elem_size = sizeof(u8),
258 .array_type = NO_ARRAY,
260 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
264 .data_type = QMI_UNSIGNED_1_BYTE,
266 .elem_size = sizeof(u8),
267 .array_type = NO_ARRAY,
269 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
273 .data_type = QMI_OPT_FLAG,
275 .elem_size = sizeof(u8),
276 .array_type = NO_ARRAY,
278 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
282 .data_type = QMI_UNSIGNED_4_BYTE,
284 .elem_size = sizeof(u32),
285 .array_type = NO_ARRAY,
287 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
291 .data_type = QMI_OPT_FLAG,
293 .elem_size = sizeof(u8),
294 .array_type = NO_ARRAY,
296 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
300 .data_type = QMI_UNSIGNED_1_BYTE,
302 .elem_size = sizeof(u8),
303 .array_type = NO_ARRAY,
305 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
309 .data_type = QMI_OPT_FLAG,
311 .elem_size = sizeof(u8),
312 .array_type = NO_ARRAY,
314 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
318 .data_type = QMI_UNSIGNED_2_BYTE,
320 .elem_size = sizeof(u16),
321 .array_type = NO_ARRAY,
323 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
327 .data_type = QMI_OPT_FLAG,
329 .elem_size = sizeof(u8),
330 .array_type = NO_ARRAY,
332 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
333 platform_name_valid),
336 .data_type = QMI_STRING,
337 .elem_len = QMI_WLANFW_MAX_PLATFORM_NAME_LEN_V01 + 1,
338 .elem_size = sizeof(char),
339 .array_type = NO_ARRAY,
341 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
345 .data_type = QMI_OPT_FLAG,
347 .elem_size = sizeof(u8),
348 .array_type = NO_ARRAY,
350 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
354 .data_type = QMI_STRUCT,
355 .elem_len = QMI_WLANFW_MAX_HOST_DDR_RANGE_SIZE_V01,
356 .elem_size = sizeof(struct qmi_wlanfw_host_ddr_range),
357 .array_type = STATIC_ARRAY,
359 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
363 .data_type = QMI_OPT_FLAG,
365 .elem_size = sizeof(u8),
366 .array_type = NO_ARRAY,
368 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
369 host_build_type_valid),
372 .data_type = QMI_SIGNED_4_BYTE_ENUM,
374 .elem_size = sizeof(enum qmi_wlanfw_host_build_type),
375 .array_type = NO_ARRAY,
377 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
381 .data_type = QMI_OPT_FLAG,
383 .elem_size = sizeof(u8),
384 .array_type = NO_ARRAY,
386 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
390 .data_type = QMI_OPT_FLAG,
392 .elem_size = sizeof(u8),
393 .array_type = NO_ARRAY,
395 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
399 .data_type = QMI_OPT_FLAG,
401 .elem_size = sizeof(u8),
402 .array_type = NO_ARRAY,
404 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
408 .data_type = QMI_UNSIGNED_2_BYTE,
410 .elem_size = sizeof(u16),
411 .array_type = NO_ARRAY,
413 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
417 .data_type = QMI_OPT_FLAG,
419 .elem_size = sizeof(u8),
420 .array_type = NO_ARRAY,
422 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
426 .data_type = QMI_UNSIGNED_1_BYTE,
428 .elem_size = sizeof(u8),
429 .array_type = NO_ARRAY,
431 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
435 .data_type = QMI_OPT_FLAG,
437 .elem_size = sizeof(u8),
438 .array_type = NO_ARRAY,
440 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
444 .data_type = QMI_UNSIGNED_2_BYTE,
446 .elem_size = sizeof(u16),
447 .array_type = NO_ARRAY,
449 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
453 .data_type = QMI_OPT_FLAG,
455 .elem_size = sizeof(u8),
456 .array_type = NO_ARRAY,
458 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
459 mlo_num_chips_valid),
462 .data_type = QMI_UNSIGNED_1_BYTE,
464 .elem_size = sizeof(u8),
465 .array_type = NO_ARRAY,
467 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
471 .data_type = QMI_OPT_FLAG,
473 .elem_size = sizeof(u8),
474 .array_type = NO_ARRAY,
476 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
477 mlo_chip_info_valid),
480 .data_type = QMI_STRUCT,
481 .elem_len = QMI_WLFW_MAX_NUM_MLO_CHIPS_V01,
482 .elem_size = sizeof(struct wlfw_host_mlo_chip_info_s_v01),
483 .array_type = STATIC_ARRAY,
485 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
487 .ei_array = wlfw_host_mlo_chip_info_s_v01_ei,
490 .data_type = QMI_OPT_FLAG,
492 .elem_size = sizeof(u8),
493 .array_type = NO_ARRAY,
495 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
499 .data_type = QMI_UNSIGNED_8_BYTE,
501 .elem_size = sizeof(u64),
502 .array_type = NO_ARRAY,
504 .offset = offsetof(struct qmi_wlanfw_host_cap_req_msg_v01,
508 .data_type = QMI_EOTI,
509 .array_type = NO_ARRAY,
510 .tlv_type = QMI_COMMON_TLV_TYPE,
514 static struct qmi_elem_info qmi_wlanfw_host_cap_resp_msg_v01_ei[] = {
516 .data_type = QMI_STRUCT,
518 .elem_size = sizeof(struct qmi_response_type_v01),
519 .array_type = NO_ARRAY,
521 .offset = offsetof(struct qmi_wlanfw_host_cap_resp_msg_v01, resp),
522 .ei_array = qmi_response_type_v01_ei,
525 .data_type = QMI_EOTI,
526 .array_type = NO_ARRAY,
527 .tlv_type = QMI_COMMON_TLV_TYPE,
531 static struct qmi_elem_info qmi_wlanfw_ind_register_req_msg_v01_ei[] = {
533 .data_type = QMI_OPT_FLAG,
535 .elem_size = sizeof(u8),
536 .array_type = NO_ARRAY,
538 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
539 fw_ready_enable_valid),
542 .data_type = QMI_UNSIGNED_1_BYTE,
544 .elem_size = sizeof(u8),
545 .array_type = NO_ARRAY,
547 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
551 .data_type = QMI_OPT_FLAG,
553 .elem_size = sizeof(u8),
554 .array_type = NO_ARRAY,
556 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
557 initiate_cal_download_enable_valid),
560 .data_type = QMI_UNSIGNED_1_BYTE,
562 .elem_size = sizeof(u8),
563 .array_type = NO_ARRAY,
565 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
566 initiate_cal_download_enable),
569 .data_type = QMI_OPT_FLAG,
571 .elem_size = sizeof(u8),
572 .array_type = NO_ARRAY,
574 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
575 initiate_cal_update_enable_valid),
578 .data_type = QMI_UNSIGNED_1_BYTE,
580 .elem_size = sizeof(u8),
581 .array_type = NO_ARRAY,
583 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
584 initiate_cal_update_enable),
587 .data_type = QMI_OPT_FLAG,
589 .elem_size = sizeof(u8),
590 .array_type = NO_ARRAY,
592 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
593 msa_ready_enable_valid),
596 .data_type = QMI_UNSIGNED_1_BYTE,
598 .elem_size = sizeof(u8),
599 .array_type = NO_ARRAY,
601 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
605 .data_type = QMI_OPT_FLAG,
607 .elem_size = sizeof(u8),
608 .array_type = NO_ARRAY,
610 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
611 pin_connect_result_enable_valid),
614 .data_type = QMI_UNSIGNED_1_BYTE,
616 .elem_size = sizeof(u8),
617 .array_type = NO_ARRAY,
619 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
620 pin_connect_result_enable),
623 .data_type = QMI_OPT_FLAG,
625 .elem_size = sizeof(u8),
626 .array_type = NO_ARRAY,
628 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
632 .data_type = QMI_UNSIGNED_4_BYTE,
634 .elem_size = sizeof(u32),
635 .array_type = NO_ARRAY,
637 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
641 .data_type = QMI_OPT_FLAG,
643 .elem_size = sizeof(u8),
644 .array_type = NO_ARRAY,
646 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
647 request_mem_enable_valid),
650 .data_type = QMI_UNSIGNED_1_BYTE,
652 .elem_size = sizeof(u8),
653 .array_type = NO_ARRAY,
655 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
659 .data_type = QMI_OPT_FLAG,
661 .elem_size = sizeof(u8),
662 .array_type = NO_ARRAY,
664 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
665 fw_mem_ready_enable_valid),
668 .data_type = QMI_UNSIGNED_1_BYTE,
670 .elem_size = sizeof(u8),
671 .array_type = NO_ARRAY,
673 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
674 fw_mem_ready_enable),
677 .data_type = QMI_OPT_FLAG,
679 .elem_size = sizeof(u8),
680 .array_type = NO_ARRAY,
682 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
683 fw_init_done_enable_valid),
686 .data_type = QMI_UNSIGNED_1_BYTE,
688 .elem_size = sizeof(u8),
689 .array_type = NO_ARRAY,
691 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
692 fw_init_done_enable),
696 .data_type = QMI_OPT_FLAG,
698 .elem_size = sizeof(u8),
699 .array_type = NO_ARRAY,
701 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
702 rejuvenate_enable_valid),
705 .data_type = QMI_UNSIGNED_1_BYTE,
707 .elem_size = sizeof(u8),
708 .array_type = NO_ARRAY,
710 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
714 .data_type = QMI_OPT_FLAG,
716 .elem_size = sizeof(u8),
717 .array_type = NO_ARRAY,
719 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
720 xo_cal_enable_valid),
723 .data_type = QMI_UNSIGNED_1_BYTE,
725 .elem_size = sizeof(u8),
726 .array_type = NO_ARRAY,
728 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
732 .data_type = QMI_OPT_FLAG,
734 .elem_size = sizeof(u8),
735 .array_type = NO_ARRAY,
737 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
738 cal_done_enable_valid),
741 .data_type = QMI_UNSIGNED_1_BYTE,
743 .elem_size = sizeof(u8),
744 .array_type = NO_ARRAY,
746 .offset = offsetof(struct qmi_wlanfw_ind_register_req_msg_v01,
750 .data_type = QMI_EOTI,
751 .array_type = NO_ARRAY,
752 .tlv_type = QMI_COMMON_TLV_TYPE,
756 static struct qmi_elem_info qmi_wlanfw_ind_register_resp_msg_v01_ei[] = {
758 .data_type = QMI_STRUCT,
760 .elem_size = sizeof(struct qmi_response_type_v01),
761 .array_type = NO_ARRAY,
763 .offset = offsetof(struct qmi_wlanfw_ind_register_resp_msg_v01,
765 .ei_array = qmi_response_type_v01_ei,
768 .data_type = QMI_OPT_FLAG,
770 .elem_size = sizeof(u8),
771 .array_type = NO_ARRAY,
773 .offset = offsetof(struct qmi_wlanfw_ind_register_resp_msg_v01,
777 .data_type = QMI_UNSIGNED_8_BYTE,
779 .elem_size = sizeof(u64),
780 .array_type = NO_ARRAY,
782 .offset = offsetof(struct qmi_wlanfw_ind_register_resp_msg_v01,
786 .data_type = QMI_EOTI,
787 .array_type = NO_ARRAY,
788 .tlv_type = QMI_COMMON_TLV_TYPE,
792 static struct qmi_elem_info qmi_wlanfw_mem_cfg_s_v01_ei[] = {
794 .data_type = QMI_UNSIGNED_8_BYTE,
796 .elem_size = sizeof(u64),
797 .array_type = NO_ARRAY,
799 .offset = offsetof(struct qmi_wlanfw_mem_cfg_s_v01, offset),
802 .data_type = QMI_UNSIGNED_4_BYTE,
804 .elem_size = sizeof(u32),
805 .array_type = NO_ARRAY,
807 .offset = offsetof(struct qmi_wlanfw_mem_cfg_s_v01, size),
810 .data_type = QMI_UNSIGNED_1_BYTE,
812 .elem_size = sizeof(u8),
813 .array_type = NO_ARRAY,
815 .offset = offsetof(struct qmi_wlanfw_mem_cfg_s_v01, secure_flag),
818 .data_type = QMI_EOTI,
819 .array_type = NO_ARRAY,
820 .tlv_type = QMI_COMMON_TLV_TYPE,
824 static struct qmi_elem_info qmi_wlanfw_mem_seg_s_v01_ei[] = {
826 .data_type = QMI_UNSIGNED_4_BYTE,
828 .elem_size = sizeof(u32),
829 .array_type = NO_ARRAY,
831 .offset = offsetof(struct qmi_wlanfw_mem_seg_s_v01,
835 .data_type = QMI_SIGNED_4_BYTE_ENUM,
837 .elem_size = sizeof(enum qmi_wlanfw_mem_type_enum_v01),
838 .array_type = NO_ARRAY,
840 .offset = offsetof(struct qmi_wlanfw_mem_seg_s_v01, type),
843 .data_type = QMI_DATA_LEN,
845 .elem_size = sizeof(u8),
846 .array_type = NO_ARRAY,
848 .offset = offsetof(struct qmi_wlanfw_mem_seg_s_v01, mem_cfg_len),
851 .data_type = QMI_STRUCT,
852 .elem_len = QMI_WLANFW_MAX_NUM_MEM_CFG_V01,
853 .elem_size = sizeof(struct qmi_wlanfw_mem_cfg_s_v01),
854 .array_type = VAR_LEN_ARRAY,
856 .offset = offsetof(struct qmi_wlanfw_mem_seg_s_v01, mem_cfg),
857 .ei_array = qmi_wlanfw_mem_cfg_s_v01_ei,
860 .data_type = QMI_EOTI,
861 .array_type = NO_ARRAY,
862 .tlv_type = QMI_COMMON_TLV_TYPE,
866 static struct qmi_elem_info qmi_wlanfw_request_mem_ind_msg_v01_ei[] = {
868 .data_type = QMI_DATA_LEN,
870 .elem_size = sizeof(u8),
871 .array_type = NO_ARRAY,
873 .offset = offsetof(struct qmi_wlanfw_request_mem_ind_msg_v01,
877 .data_type = QMI_STRUCT,
878 .elem_len = ATH12K_QMI_WLANFW_MAX_NUM_MEM_SEG_V01,
879 .elem_size = sizeof(struct qmi_wlanfw_mem_seg_s_v01),
880 .array_type = VAR_LEN_ARRAY,
882 .offset = offsetof(struct qmi_wlanfw_request_mem_ind_msg_v01,
884 .ei_array = qmi_wlanfw_mem_seg_s_v01_ei,
887 .data_type = QMI_EOTI,
888 .array_type = NO_ARRAY,
889 .tlv_type = QMI_COMMON_TLV_TYPE,
893 static struct qmi_elem_info qmi_wlanfw_mem_seg_resp_s_v01_ei[] = {
895 .data_type = QMI_UNSIGNED_8_BYTE,
897 .elem_size = sizeof(u64),
898 .array_type = NO_ARRAY,
900 .offset = offsetof(struct qmi_wlanfw_mem_seg_resp_s_v01, addr),
903 .data_type = QMI_UNSIGNED_4_BYTE,
905 .elem_size = sizeof(u32),
906 .array_type = NO_ARRAY,
908 .offset = offsetof(struct qmi_wlanfw_mem_seg_resp_s_v01, size),
911 .data_type = QMI_SIGNED_4_BYTE_ENUM,
913 .elem_size = sizeof(enum qmi_wlanfw_mem_type_enum_v01),
914 .array_type = NO_ARRAY,
916 .offset = offsetof(struct qmi_wlanfw_mem_seg_resp_s_v01, type),
919 .data_type = QMI_UNSIGNED_1_BYTE,
921 .elem_size = sizeof(u8),
922 .array_type = NO_ARRAY,
924 .offset = offsetof(struct qmi_wlanfw_mem_seg_resp_s_v01, restore),
927 .data_type = QMI_EOTI,
928 .array_type = NO_ARRAY,
929 .tlv_type = QMI_COMMON_TLV_TYPE,
933 static struct qmi_elem_info qmi_wlanfw_respond_mem_req_msg_v01_ei[] = {
935 .data_type = QMI_DATA_LEN,
937 .elem_size = sizeof(u8),
938 .array_type = NO_ARRAY,
940 .offset = offsetof(struct qmi_wlanfw_respond_mem_req_msg_v01,
944 .data_type = QMI_STRUCT,
945 .elem_len = ATH12K_QMI_WLANFW_MAX_NUM_MEM_SEG_V01,
946 .elem_size = sizeof(struct qmi_wlanfw_mem_seg_resp_s_v01),
947 .array_type = VAR_LEN_ARRAY,
949 .offset = offsetof(struct qmi_wlanfw_respond_mem_req_msg_v01,
951 .ei_array = qmi_wlanfw_mem_seg_resp_s_v01_ei,
954 .data_type = QMI_EOTI,
955 .array_type = NO_ARRAY,
956 .tlv_type = QMI_COMMON_TLV_TYPE,
960 static struct qmi_elem_info qmi_wlanfw_respond_mem_resp_msg_v01_ei[] = {
962 .data_type = QMI_STRUCT,
964 .elem_size = sizeof(struct qmi_response_type_v01),
965 .array_type = NO_ARRAY,
967 .offset = offsetof(struct qmi_wlanfw_respond_mem_resp_msg_v01,
969 .ei_array = qmi_response_type_v01_ei,
972 .data_type = QMI_EOTI,
973 .array_type = NO_ARRAY,
974 .tlv_type = QMI_COMMON_TLV_TYPE,
978 static struct qmi_elem_info qmi_wlanfw_cap_req_msg_v01_ei[] = {
980 .data_type = QMI_EOTI,
981 .array_type = NO_ARRAY,
982 .tlv_type = QMI_COMMON_TLV_TYPE,
986 static struct qmi_elem_info qmi_wlanfw_rf_chip_info_s_v01_ei[] = {
988 .data_type = QMI_UNSIGNED_4_BYTE,
990 .elem_size = sizeof(u32),
991 .array_type = NO_ARRAY,
993 .offset = offsetof(struct qmi_wlanfw_rf_chip_info_s_v01,
997 .data_type = QMI_UNSIGNED_4_BYTE,
999 .elem_size = sizeof(u32),
1000 .array_type = NO_ARRAY,
1002 .offset = offsetof(struct qmi_wlanfw_rf_chip_info_s_v01,
1006 .data_type = QMI_EOTI,
1007 .array_type = NO_ARRAY,
1008 .tlv_type = QMI_COMMON_TLV_TYPE,
1012 static struct qmi_elem_info qmi_wlanfw_rf_board_info_s_v01_ei[] = {
1014 .data_type = QMI_UNSIGNED_4_BYTE,
1016 .elem_size = sizeof(u32),
1017 .array_type = NO_ARRAY,
1019 .offset = offsetof(struct qmi_wlanfw_rf_board_info_s_v01,
1023 .data_type = QMI_EOTI,
1024 .array_type = NO_ARRAY,
1025 .tlv_type = QMI_COMMON_TLV_TYPE,
1029 static struct qmi_elem_info qmi_wlanfw_soc_info_s_v01_ei[] = {
1031 .data_type = QMI_UNSIGNED_4_BYTE,
1033 .elem_size = sizeof(u32),
1034 .array_type = NO_ARRAY,
1036 .offset = offsetof(struct qmi_wlanfw_soc_info_s_v01, soc_id),
1039 .data_type = QMI_EOTI,
1040 .array_type = NO_ARRAY,
1041 .tlv_type = QMI_COMMON_TLV_TYPE,
1045 static struct qmi_elem_info qmi_wlanfw_dev_mem_info_s_v01_ei[] = {
1047 .data_type = QMI_UNSIGNED_8_BYTE,
1049 .elem_size = sizeof(u64),
1050 .array_type = NO_ARRAY,
1052 .offset = offsetof(struct qmi_wlanfw_dev_mem_info_s_v01,
1056 .data_type = QMI_UNSIGNED_8_BYTE,
1058 .elem_size = sizeof(u64),
1059 .array_type = NO_ARRAY,
1061 .offset = offsetof(struct qmi_wlanfw_dev_mem_info_s_v01,
1065 .data_type = QMI_EOTI,
1066 .array_type = NO_ARRAY,
1067 .tlv_type = QMI_COMMON_TLV_TYPE,
1071 static struct qmi_elem_info qmi_wlanfw_fw_version_info_s_v01_ei[] = {
1073 .data_type = QMI_UNSIGNED_4_BYTE,
1075 .elem_size = sizeof(u32),
1076 .array_type = NO_ARRAY,
1078 .offset = offsetof(struct qmi_wlanfw_fw_version_info_s_v01,
1082 .data_type = QMI_STRING,
1083 .elem_len = ATH12K_QMI_WLANFW_MAX_TIMESTAMP_LEN_V01 + 1,
1084 .elem_size = sizeof(char),
1085 .array_type = NO_ARRAY,
1087 .offset = offsetof(struct qmi_wlanfw_fw_version_info_s_v01,
1088 fw_build_timestamp),
1091 .data_type = QMI_EOTI,
1092 .array_type = NO_ARRAY,
1093 .tlv_type = QMI_COMMON_TLV_TYPE,
1097 static struct qmi_elem_info qmi_wlanfw_cap_resp_msg_v01_ei[] = {
1099 .data_type = QMI_STRUCT,
1101 .elem_size = sizeof(struct qmi_response_type_v01),
1102 .array_type = NO_ARRAY,
1104 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01, resp),
1105 .ei_array = qmi_response_type_v01_ei,
1108 .data_type = QMI_OPT_FLAG,
1110 .elem_size = sizeof(u8),
1111 .array_type = NO_ARRAY,
1113 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1117 .data_type = QMI_STRUCT,
1119 .elem_size = sizeof(struct qmi_wlanfw_rf_chip_info_s_v01),
1120 .array_type = NO_ARRAY,
1122 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1124 .ei_array = qmi_wlanfw_rf_chip_info_s_v01_ei,
1127 .data_type = QMI_OPT_FLAG,
1129 .elem_size = sizeof(u8),
1130 .array_type = NO_ARRAY,
1132 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1136 .data_type = QMI_STRUCT,
1138 .elem_size = sizeof(struct qmi_wlanfw_rf_board_info_s_v01),
1139 .array_type = NO_ARRAY,
1141 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1143 .ei_array = qmi_wlanfw_rf_board_info_s_v01_ei,
1146 .data_type = QMI_OPT_FLAG,
1148 .elem_size = sizeof(u8),
1149 .array_type = NO_ARRAY,
1151 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1155 .data_type = QMI_STRUCT,
1157 .elem_size = sizeof(struct qmi_wlanfw_soc_info_s_v01),
1158 .array_type = NO_ARRAY,
1160 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1162 .ei_array = qmi_wlanfw_soc_info_s_v01_ei,
1165 .data_type = QMI_OPT_FLAG,
1167 .elem_size = sizeof(u8),
1168 .array_type = NO_ARRAY,
1170 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1171 fw_version_info_valid),
1174 .data_type = QMI_STRUCT,
1176 .elem_size = sizeof(struct qmi_wlanfw_fw_version_info_s_v01),
1177 .array_type = NO_ARRAY,
1179 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1181 .ei_array = qmi_wlanfw_fw_version_info_s_v01_ei,
1184 .data_type = QMI_OPT_FLAG,
1186 .elem_size = sizeof(u8),
1187 .array_type = NO_ARRAY,
1189 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1193 .data_type = QMI_STRING,
1194 .elem_len = ATH12K_QMI_WLANFW_MAX_BUILD_ID_LEN_V01 + 1,
1195 .elem_size = sizeof(char),
1196 .array_type = NO_ARRAY,
1198 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1202 .data_type = QMI_OPT_FLAG,
1204 .elem_size = sizeof(u8),
1205 .array_type = NO_ARRAY,
1207 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1211 .data_type = QMI_UNSIGNED_1_BYTE,
1213 .elem_size = sizeof(u8),
1214 .array_type = NO_ARRAY,
1216 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1220 .data_type = QMI_OPT_FLAG,
1222 .elem_size = sizeof(u8),
1223 .array_type = NO_ARRAY,
1225 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1229 .data_type = QMI_UNSIGNED_4_BYTE,
1231 .elem_size = sizeof(u32),
1232 .array_type = NO_ARRAY,
1234 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1238 .data_type = QMI_OPT_FLAG,
1240 .elem_size = sizeof(u8),
1241 .array_type = NO_ARRAY,
1243 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1244 time_freq_hz_valid),
1247 .data_type = QMI_UNSIGNED_4_BYTE,
1249 .elem_size = sizeof(u32),
1250 .array_type = NO_ARRAY,
1252 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1256 .data_type = QMI_OPT_FLAG,
1258 .elem_size = sizeof(u8),
1259 .array_type = NO_ARRAY,
1261 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1265 .data_type = QMI_UNSIGNED_4_BYTE,
1267 .elem_size = sizeof(u32),
1268 .array_type = NO_ARRAY,
1270 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1274 .data_type = QMI_OPT_FLAG,
1276 .elem_size = sizeof(u8),
1277 .array_type = NO_ARRAY,
1279 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1280 eeprom_caldata_read_timeout_valid),
1283 .data_type = QMI_UNSIGNED_4_BYTE,
1285 .elem_size = sizeof(u32),
1286 .array_type = NO_ARRAY,
1288 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1289 eeprom_caldata_read_timeout),
1292 .data_type = QMI_OPT_FLAG,
1294 .elem_size = sizeof(u8),
1295 .array_type = NO_ARRAY,
1297 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1301 .data_type = QMI_UNSIGNED_8_BYTE,
1303 .elem_size = sizeof(u64),
1304 .array_type = NO_ARRAY,
1306 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01, fw_caps),
1309 .data_type = QMI_OPT_FLAG,
1311 .elem_size = sizeof(u8),
1312 .array_type = NO_ARRAY,
1314 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1315 rd_card_chain_cap_valid),
1318 .data_type = QMI_UNSIGNED_4_BYTE,
1320 .elem_size = sizeof(u32),
1321 .array_type = NO_ARRAY,
1323 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1327 .data_type = QMI_OPT_FLAG,
1329 .elem_size = sizeof(u8),
1330 .array_type = NO_ARRAY,
1332 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01,
1333 dev_mem_info_valid),
1336 .data_type = QMI_STRUCT,
1337 .elem_len = ATH12K_QMI_WLFW_MAX_DEV_MEM_NUM_V01,
1338 .elem_size = sizeof(struct qmi_wlanfw_dev_mem_info_s_v01),
1339 .array_type = STATIC_ARRAY,
1341 .offset = offsetof(struct qmi_wlanfw_cap_resp_msg_v01, dev_mem),
1342 .ei_array = qmi_wlanfw_dev_mem_info_s_v01_ei,
1345 .data_type = QMI_EOTI,
1346 .array_type = NO_ARRAY,
1347 .tlv_type = QMI_COMMON_TLV_TYPE,
1351 static struct qmi_elem_info qmi_wlanfw_bdf_download_req_msg_v01_ei[] = {
1353 .data_type = QMI_UNSIGNED_1_BYTE,
1355 .elem_size = sizeof(u8),
1356 .array_type = NO_ARRAY,
1358 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1362 .data_type = QMI_OPT_FLAG,
1364 .elem_size = sizeof(u8),
1365 .array_type = NO_ARRAY,
1367 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1371 .data_type = QMI_SIGNED_4_BYTE_ENUM,
1373 .elem_size = sizeof(enum qmi_wlanfw_cal_temp_id_enum_v01),
1374 .array_type = NO_ARRAY,
1376 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1380 .data_type = QMI_OPT_FLAG,
1382 .elem_size = sizeof(u8),
1383 .array_type = NO_ARRAY,
1385 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1389 .data_type = QMI_UNSIGNED_4_BYTE,
1391 .elem_size = sizeof(u32),
1392 .array_type = NO_ARRAY,
1394 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1398 .data_type = QMI_OPT_FLAG,
1400 .elem_size = sizeof(u8),
1401 .array_type = NO_ARRAY,
1403 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1407 .data_type = QMI_UNSIGNED_4_BYTE,
1409 .elem_size = sizeof(u32),
1410 .array_type = NO_ARRAY,
1412 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1416 .data_type = QMI_OPT_FLAG,
1418 .elem_size = sizeof(u8),
1419 .array_type = NO_ARRAY,
1421 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1425 .data_type = QMI_DATA_LEN,
1427 .elem_size = sizeof(u16),
1428 .array_type = NO_ARRAY,
1430 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1434 .data_type = QMI_UNSIGNED_1_BYTE,
1435 .elem_len = QMI_WLANFW_MAX_DATA_SIZE_V01,
1436 .elem_size = sizeof(u8),
1437 .array_type = VAR_LEN_ARRAY,
1439 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1443 .data_type = QMI_OPT_FLAG,
1445 .elem_size = sizeof(u8),
1446 .array_type = NO_ARRAY,
1448 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1452 .data_type = QMI_UNSIGNED_1_BYTE,
1454 .elem_size = sizeof(u8),
1455 .array_type = NO_ARRAY,
1457 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1461 .data_type = QMI_OPT_FLAG,
1463 .elem_size = sizeof(u8),
1464 .array_type = NO_ARRAY,
1466 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1470 .data_type = QMI_UNSIGNED_1_BYTE,
1472 .elem_size = sizeof(u8),
1473 .array_type = NO_ARRAY,
1475 .offset = offsetof(struct qmi_wlanfw_bdf_download_req_msg_v01,
1480 .data_type = QMI_EOTI,
1481 .array_type = NO_ARRAY,
1482 .tlv_type = QMI_COMMON_TLV_TYPE,
1486 static struct qmi_elem_info qmi_wlanfw_bdf_download_resp_msg_v01_ei[] = {
1488 .data_type = QMI_STRUCT,
1490 .elem_size = sizeof(struct qmi_response_type_v01),
1491 .array_type = NO_ARRAY,
1493 .offset = offsetof(struct qmi_wlanfw_bdf_download_resp_msg_v01,
1495 .ei_array = qmi_response_type_v01_ei,
1498 .data_type = QMI_EOTI,
1499 .array_type = NO_ARRAY,
1500 .tlv_type = QMI_COMMON_TLV_TYPE,
1504 static struct qmi_elem_info qmi_wlanfw_m3_info_req_msg_v01_ei[] = {
1506 .data_type = QMI_UNSIGNED_8_BYTE,
1508 .elem_size = sizeof(u64),
1509 .array_type = NO_ARRAY,
1511 .offset = offsetof(struct qmi_wlanfw_m3_info_req_msg_v01, addr),
1514 .data_type = QMI_UNSIGNED_4_BYTE,
1516 .elem_size = sizeof(u32),
1517 .array_type = NO_ARRAY,
1519 .offset = offsetof(struct qmi_wlanfw_m3_info_req_msg_v01, size),
1522 .data_type = QMI_EOTI,
1523 .array_type = NO_ARRAY,
1524 .tlv_type = QMI_COMMON_TLV_TYPE,
1528 static struct qmi_elem_info qmi_wlanfw_m3_info_resp_msg_v01_ei[] = {
1530 .data_type = QMI_STRUCT,
1532 .elem_size = sizeof(struct qmi_response_type_v01),
1533 .array_type = NO_ARRAY,
1535 .offset = offsetof(struct qmi_wlanfw_m3_info_resp_msg_v01, resp),
1536 .ei_array = qmi_response_type_v01_ei,
1539 .data_type = QMI_EOTI,
1540 .array_type = NO_ARRAY,
1541 .tlv_type = QMI_COMMON_TLV_TYPE,
1545 static struct qmi_elem_info qmi_wlanfw_ce_tgt_pipe_cfg_s_v01_ei[] = {
1547 .data_type = QMI_UNSIGNED_4_BYTE,
1549 .elem_size = sizeof(u32),
1550 .array_type = NO_ARRAY,
1552 .offset = offsetof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01,
1556 .data_type = QMI_SIGNED_4_BYTE_ENUM,
1558 .elem_size = sizeof(enum qmi_wlanfw_pipedir_enum_v01),
1559 .array_type = NO_ARRAY,
1561 .offset = offsetof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01,
1565 .data_type = QMI_UNSIGNED_4_BYTE,
1567 .elem_size = sizeof(u32),
1568 .array_type = NO_ARRAY,
1570 .offset = offsetof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01,
1574 .data_type = QMI_UNSIGNED_4_BYTE,
1576 .elem_size = sizeof(u32),
1577 .array_type = NO_ARRAY,
1579 .offset = offsetof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01,
1583 .data_type = QMI_UNSIGNED_4_BYTE,
1585 .elem_size = sizeof(u32),
1586 .array_type = NO_ARRAY,
1588 .offset = offsetof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01,
1592 .data_type = QMI_EOTI,
1593 .array_type = NO_ARRAY,
1594 .tlv_type = QMI_COMMON_TLV_TYPE,
1598 static struct qmi_elem_info qmi_wlanfw_ce_svc_pipe_cfg_s_v01_ei[] = {
1600 .data_type = QMI_UNSIGNED_4_BYTE,
1602 .elem_size = sizeof(u32),
1603 .array_type = NO_ARRAY,
1605 .offset = offsetof(struct qmi_wlanfw_ce_svc_pipe_cfg_s_v01,
1609 .data_type = QMI_SIGNED_4_BYTE_ENUM,
1611 .elem_size = sizeof(enum qmi_wlanfw_pipedir_enum_v01),
1612 .array_type = NO_ARRAY,
1614 .offset = offsetof(struct qmi_wlanfw_ce_svc_pipe_cfg_s_v01,
1618 .data_type = QMI_UNSIGNED_4_BYTE,
1620 .elem_size = sizeof(u32),
1621 .array_type = NO_ARRAY,
1623 .offset = offsetof(struct qmi_wlanfw_ce_svc_pipe_cfg_s_v01,
1627 .data_type = QMI_EOTI,
1628 .array_type = NO_ARRAY,
1629 .tlv_type = QMI_COMMON_TLV_TYPE,
1633 static struct qmi_elem_info qmi_wlanfw_shadow_reg_cfg_s_v01_ei[] = {
1635 .data_type = QMI_UNSIGNED_2_BYTE,
1637 .elem_size = sizeof(u16),
1638 .array_type = NO_ARRAY,
1640 .offset = offsetof(struct qmi_wlanfw_shadow_reg_cfg_s_v01, id),
1643 .data_type = QMI_UNSIGNED_2_BYTE,
1645 .elem_size = sizeof(u16),
1646 .array_type = NO_ARRAY,
1648 .offset = offsetof(struct qmi_wlanfw_shadow_reg_cfg_s_v01,
1652 .data_type = QMI_EOTI,
1653 .array_type = QMI_COMMON_TLV_TYPE,
1657 static struct qmi_elem_info qmi_wlanfw_shadow_reg_v3_cfg_s_v01_ei[] = {
1659 .data_type = QMI_UNSIGNED_4_BYTE,
1661 .elem_size = sizeof(u32),
1662 .array_type = NO_ARRAY,
1664 .offset = offsetof(struct qmi_wlanfw_shadow_reg_v3_cfg_s_v01,
1668 .data_type = QMI_EOTI,
1669 .array_type = NO_ARRAY,
1670 .tlv_type = QMI_COMMON_TLV_TYPE,
1674 static struct qmi_elem_info qmi_wlanfw_wlan_mode_req_msg_v01_ei[] = {
1676 .data_type = QMI_UNSIGNED_4_BYTE,
1678 .elem_size = sizeof(u32),
1679 .array_type = NO_ARRAY,
1681 .offset = offsetof(struct qmi_wlanfw_wlan_mode_req_msg_v01,
1685 .data_type = QMI_OPT_FLAG,
1687 .elem_size = sizeof(u8),
1688 .array_type = NO_ARRAY,
1690 .offset = offsetof(struct qmi_wlanfw_wlan_mode_req_msg_v01,
1694 .data_type = QMI_UNSIGNED_1_BYTE,
1696 .elem_size = sizeof(u8),
1697 .array_type = NO_ARRAY,
1699 .offset = offsetof(struct qmi_wlanfw_wlan_mode_req_msg_v01,
1703 .data_type = QMI_EOTI,
1704 .array_type = NO_ARRAY,
1705 .tlv_type = QMI_COMMON_TLV_TYPE,
1709 static struct qmi_elem_info qmi_wlanfw_wlan_mode_resp_msg_v01_ei[] = {
1711 .data_type = QMI_STRUCT,
1713 .elem_size = sizeof(struct qmi_response_type_v01),
1714 .array_type = NO_ARRAY,
1716 .offset = offsetof(struct qmi_wlanfw_wlan_mode_resp_msg_v01,
1718 .ei_array = qmi_response_type_v01_ei,
1721 .data_type = QMI_EOTI,
1722 .array_type = NO_ARRAY,
1723 .tlv_type = QMI_COMMON_TLV_TYPE,
1727 static struct qmi_elem_info qmi_wlanfw_wlan_cfg_req_msg_v01_ei[] = {
1729 .data_type = QMI_OPT_FLAG,
1731 .elem_size = sizeof(u8),
1732 .array_type = NO_ARRAY,
1734 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1735 host_version_valid),
1738 .data_type = QMI_STRING,
1739 .elem_len = QMI_WLANFW_MAX_STR_LEN_V01 + 1,
1740 .elem_size = sizeof(char),
1741 .array_type = NO_ARRAY,
1743 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1747 .data_type = QMI_OPT_FLAG,
1749 .elem_size = sizeof(u8),
1750 .array_type = NO_ARRAY,
1752 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1756 .data_type = QMI_DATA_LEN,
1758 .elem_size = sizeof(u8),
1759 .array_type = NO_ARRAY,
1761 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1765 .data_type = QMI_STRUCT,
1766 .elem_len = QMI_WLANFW_MAX_NUM_CE_V01,
1767 .elem_size = sizeof(struct qmi_wlanfw_ce_tgt_pipe_cfg_s_v01),
1768 .array_type = VAR_LEN_ARRAY,
1770 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1772 .ei_array = qmi_wlanfw_ce_tgt_pipe_cfg_s_v01_ei,
1775 .data_type = QMI_OPT_FLAG,
1777 .elem_size = sizeof(u8),
1778 .array_type = NO_ARRAY,
1780 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1784 .data_type = QMI_DATA_LEN,
1786 .elem_size = sizeof(u8),
1787 .array_type = NO_ARRAY,
1789 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1793 .data_type = QMI_STRUCT,
1794 .elem_len = QMI_WLANFW_MAX_NUM_SVC_V01,
1795 .elem_size = sizeof(struct qmi_wlanfw_ce_svc_pipe_cfg_s_v01),
1796 .array_type = VAR_LEN_ARRAY,
1798 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1800 .ei_array = qmi_wlanfw_ce_svc_pipe_cfg_s_v01_ei,
1803 .data_type = QMI_OPT_FLAG,
1805 .elem_size = sizeof(u8),
1806 .array_type = NO_ARRAY,
1808 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1812 .data_type = QMI_DATA_LEN,
1814 .elem_size = sizeof(u8),
1815 .array_type = NO_ARRAY,
1817 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1821 .data_type = QMI_STRUCT,
1822 .elem_len = QMI_WLANFW_MAX_NUM_SHADOW_REG_V01,
1823 .elem_size = sizeof(struct qmi_wlanfw_shadow_reg_cfg_s_v01),
1824 .array_type = VAR_LEN_ARRAY,
1826 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1828 .ei_array = qmi_wlanfw_shadow_reg_cfg_s_v01_ei,
1831 .data_type = QMI_OPT_FLAG,
1833 .elem_size = sizeof(u8),
1834 .array_type = NO_ARRAY,
1836 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1837 shadow_reg_v3_valid),
1840 .data_type = QMI_DATA_LEN,
1842 .elem_size = sizeof(u8),
1843 .array_type = NO_ARRAY,
1845 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1849 .data_type = QMI_STRUCT,
1850 .elem_len = QMI_WLANFW_MAX_NUM_SHADOW_REG_V3_V01,
1851 .elem_size = sizeof(struct qmi_wlanfw_shadow_reg_v3_cfg_s_v01),
1852 .array_type = VAR_LEN_ARRAY,
1854 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_req_msg_v01,
1856 .ei_array = qmi_wlanfw_shadow_reg_v3_cfg_s_v01_ei,
1859 .data_type = QMI_EOTI,
1860 .array_type = NO_ARRAY,
1861 .tlv_type = QMI_COMMON_TLV_TYPE,
1865 static struct qmi_elem_info qmi_wlanfw_wlan_cfg_resp_msg_v01_ei[] = {
1867 .data_type = QMI_STRUCT,
1869 .elem_size = sizeof(struct qmi_response_type_v01),
1870 .array_type = NO_ARRAY,
1872 .offset = offsetof(struct qmi_wlanfw_wlan_cfg_resp_msg_v01, resp),
1873 .ei_array = qmi_response_type_v01_ei,
1876 .data_type = QMI_EOTI,
1877 .array_type = NO_ARRAY,
1878 .tlv_type = QMI_COMMON_TLV_TYPE,
1882 static struct qmi_elem_info qmi_wlanfw_mem_ready_ind_msg_v01_ei[] = {
1884 .data_type = QMI_EOTI,
1885 .array_type = NO_ARRAY,
1889 static struct qmi_elem_info qmi_wlanfw_fw_ready_ind_msg_v01_ei[] = {
1891 .data_type = QMI_EOTI,
1892 .array_type = NO_ARRAY,
1896 static void ath12k_host_cap_parse_mlo(struct qmi_wlanfw_host_cap_req_msg_v01 *req)
1898 req->mlo_capable_valid = 1;
1899 req->mlo_capable = 1;
1900 req->mlo_chip_id_valid = 1;
1901 req->mlo_chip_id = 0;
1902 req->mlo_group_id_valid = 1;
1903 req->mlo_group_id = 0;
1904 req->max_mlo_peer_valid = 1;
1905 /* Max peer number generally won't change for the same device
1906 * but needs to be synced with host driver.
1908 req->max_mlo_peer = 32;
1909 req->mlo_num_chips_valid = 1;
1910 req->mlo_num_chips = 1;
1911 req->mlo_chip_info_valid = 1;
1912 req->mlo_chip_info[0].chip_id = 0;
1913 req->mlo_chip_info[0].num_local_links = 2;
1914 req->mlo_chip_info[0].hw_link_id[0] = 0;
1915 req->mlo_chip_info[0].hw_link_id[1] = 1;
1916 req->mlo_chip_info[0].valid_mlo_link_id[0] = 1;
1917 req->mlo_chip_info[0].valid_mlo_link_id[1] = 1;
1920 static int ath12k_qmi_host_cap_send(struct ath12k_base *ab)
1922 struct qmi_wlanfw_host_cap_req_msg_v01 req;
1923 struct qmi_wlanfw_host_cap_resp_msg_v01 resp;
1924 struct qmi_txn txn = {};
1927 memset(&req, 0, sizeof(req));
1928 memset(&resp, 0, sizeof(resp));
1930 req.num_clients_valid = 1;
1931 req.num_clients = 1;
1932 req.mem_cfg_mode = ab->qmi.target_mem_mode;
1933 req.mem_cfg_mode_valid = 1;
1934 req.bdf_support_valid = 1;
1935 req.bdf_support = 1;
1937 req.m3_support_valid = 1;
1939 req.m3_cache_support_valid = 1;
1940 req.m3_cache_support = 1;
1942 req.cal_done_valid = 1;
1943 req.cal_done = ab->qmi.cal_done;
1945 if (ab->hw_params->qmi_cnss_feature_bitmap) {
1946 req.feature_list_valid = 1;
1947 req.feature_list = ab->hw_params->qmi_cnss_feature_bitmap;
1950 /* BRINGUP: here we are piggybacking a lot of stuff using
1951 * internal_sleep_clock, should it be split?
1953 if (ab->hw_params->internal_sleep_clock) {
1954 req.nm_modem_valid = 1;
1956 /* Notify firmware that this is non-qualcomm platform. */
1957 req.nm_modem |= HOST_CSTATE_BIT;
1959 /* Notify firmware about the sleep clock selection,
1960 * nm_modem_bit[1] is used for this purpose. Host driver on
1961 * non-qualcomm platforms should select internal sleep
1964 req.nm_modem |= SLEEP_CLOCK_SELECT_INTERNAL_BIT;
1965 req.nm_modem |= PLATFORM_CAP_PCIE_GLOBAL_RESET;
1967 ath12k_host_cap_parse_mlo(&req);
1970 ret = qmi_txn_init(&ab->qmi.handle, &txn,
1971 qmi_wlanfw_host_cap_resp_msg_v01_ei, &resp);
1975 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
1976 QMI_WLANFW_HOST_CAP_REQ_V01,
1977 QMI_WLANFW_HOST_CAP_REQ_MSG_V01_MAX_LEN,
1978 qmi_wlanfw_host_cap_req_msg_v01_ei, &req);
1980 ath12k_warn(ab, "Failed to send host capability request,err = %d\n", ret);
1984 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
1988 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
1989 ath12k_warn(ab, "Host capability request failed, result: %d, err: %d\n",
1990 resp.resp.result, resp.resp.error);
1999 static int ath12k_qmi_fw_ind_register_send(struct ath12k_base *ab)
2001 struct qmi_wlanfw_ind_register_req_msg_v01 *req;
2002 struct qmi_wlanfw_ind_register_resp_msg_v01 *resp;
2003 struct qmi_handle *handle = &ab->qmi.handle;
2007 req = kzalloc(sizeof(*req), GFP_KERNEL);
2011 resp = kzalloc(sizeof(*resp), GFP_KERNEL);
2017 req->client_id_valid = 1;
2018 req->client_id = QMI_WLANFW_CLIENT_ID;
2019 req->fw_ready_enable_valid = 1;
2020 req->fw_ready_enable = 1;
2021 req->request_mem_enable_valid = 1;
2022 req->request_mem_enable = 1;
2023 req->fw_mem_ready_enable_valid = 1;
2024 req->fw_mem_ready_enable = 1;
2025 req->cal_done_enable_valid = 1;
2026 req->cal_done_enable = 1;
2027 req->fw_init_done_enable_valid = 1;
2028 req->fw_init_done_enable = 1;
2030 req->pin_connect_result_enable_valid = 0;
2031 req->pin_connect_result_enable = 0;
2033 ret = qmi_txn_init(handle, &txn,
2034 qmi_wlanfw_ind_register_resp_msg_v01_ei, resp);
2038 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2039 QMI_WLANFW_IND_REGISTER_REQ_V01,
2040 QMI_WLANFW_IND_REGISTER_REQ_MSG_V01_MAX_LEN,
2041 qmi_wlanfw_ind_register_req_msg_v01_ei, req);
2043 ath12k_warn(ab, "Failed to send indication register request, err = %d\n",
2048 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2050 ath12k_warn(ab, "failed to register fw indication %d\n", ret);
2054 if (resp->resp.result != QMI_RESULT_SUCCESS_V01) {
2055 ath12k_warn(ab, "FW Ind register request failed, result: %d, err: %d\n",
2056 resp->resp.result, resp->resp.error);
2068 static int ath12k_qmi_respond_fw_mem_request(struct ath12k_base *ab)
2070 struct qmi_wlanfw_respond_mem_req_msg_v01 *req;
2071 struct qmi_wlanfw_respond_mem_resp_msg_v01 resp;
2072 struct qmi_txn txn = {};
2076 req = kzalloc(sizeof(*req), GFP_KERNEL);
2080 memset(&resp, 0, sizeof(resp));
2082 /* Some targets by default request a block of big contiguous
2083 * DMA memory, it's hard to allocate from kernel. So host returns
2084 * failure to firmware and firmware then request multiple blocks of
2085 * small chunk size memory.
2087 if (ab->qmi.target_mem_delayed) {
2089 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi delays mem_request %d\n",
2090 ab->qmi.mem_seg_count);
2091 memset(req, 0, sizeof(*req));
2094 req->mem_seg_len = ab->qmi.mem_seg_count;
2095 for (i = 0; i < req->mem_seg_len ; i++) {
2096 req->mem_seg[i].addr = ab->qmi.target_mem[i].paddr;
2097 req->mem_seg[i].size = ab->qmi.target_mem[i].size;
2098 req->mem_seg[i].type = ab->qmi.target_mem[i].type;
2099 ath12k_dbg(ab, ATH12K_DBG_QMI,
2100 "qmi req mem_seg[%d] %pad %u %u\n", i,
2101 &ab->qmi.target_mem[i].paddr,
2102 ab->qmi.target_mem[i].size,
2103 ab->qmi.target_mem[i].type);
2107 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2108 qmi_wlanfw_respond_mem_resp_msg_v01_ei, &resp);
2112 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2113 QMI_WLANFW_RESPOND_MEM_REQ_V01,
2114 QMI_WLANFW_RESPOND_MEM_REQ_MSG_V01_MAX_LEN,
2115 qmi_wlanfw_respond_mem_req_msg_v01_ei, req);
2117 ath12k_warn(ab, "qmi failed to respond memory request, err = %d\n",
2122 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2124 ath12k_warn(ab, "qmi failed memory request, err = %d\n", ret);
2128 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2129 /* the error response is expected when
2130 * target_mem_delayed is true.
2132 if (delayed && resp.resp.error == 0)
2135 ath12k_warn(ab, "Respond mem req failed, result: %d, err: %d\n",
2136 resp.resp.result, resp.resp.error);
2145 static void ath12k_qmi_free_target_mem_chunk(struct ath12k_base *ab)
2149 for (i = 0; i < ab->qmi.mem_seg_count; i++) {
2150 if (!ab->qmi.target_mem[i].v.addr)
2152 dma_free_coherent(ab->dev,
2153 ab->qmi.target_mem[i].size,
2154 ab->qmi.target_mem[i].v.addr,
2155 ab->qmi.target_mem[i].paddr);
2156 ab->qmi.target_mem[i].v.addr = NULL;
2160 static int ath12k_qmi_alloc_target_mem_chunk(struct ath12k_base *ab)
2163 struct target_mem_chunk *chunk;
2165 ab->qmi.target_mem_delayed = false;
2167 for (i = 0; i < ab->qmi.mem_seg_count; i++) {
2168 chunk = &ab->qmi.target_mem[i];
2170 /* Allocate memory for the region and the functionality supported
2171 * on the host. For the non-supported memory region, host does not
2172 * allocate memory, assigns NULL and FW will handle this without crashing.
2174 switch (chunk->type) {
2175 case HOST_DDR_REGION_TYPE:
2176 case M3_DUMP_REGION_TYPE:
2177 case PAGEABLE_MEM_REGION_TYPE:
2178 case CALDB_MEM_REGION_TYPE:
2179 chunk->v.addr = dma_alloc_coherent(ab->dev,
2182 GFP_KERNEL | __GFP_NOWARN);
2183 if (!chunk->v.addr) {
2184 if (chunk->size > ATH12K_QMI_MAX_CHUNK_SIZE) {
2185 ab->qmi.target_mem_delayed = true;
2187 "qmi dma allocation failed (%d B type %u), will try later with small size\n",
2190 ath12k_qmi_free_target_mem_chunk(ab);
2193 ath12k_warn(ab, "memory allocation failure for %u size: %d\n",
2194 chunk->type, chunk->size);
2199 ath12k_warn(ab, "memory type %u not supported\n",
2202 chunk->v.addr = NULL;
2209 static int ath12k_qmi_request_target_cap(struct ath12k_base *ab)
2211 struct qmi_wlanfw_cap_req_msg_v01 req;
2212 struct qmi_wlanfw_cap_resp_msg_v01 resp;
2213 struct qmi_txn txn = {};
2214 unsigned int board_id = ATH12K_BOARD_ID_DEFAULT;
2218 memset(&req, 0, sizeof(req));
2219 memset(&resp, 0, sizeof(resp));
2221 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2222 qmi_wlanfw_cap_resp_msg_v01_ei, &resp);
2226 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2227 QMI_WLANFW_CAP_REQ_V01,
2228 QMI_WLANFW_CAP_REQ_MSG_V01_MAX_LEN,
2229 qmi_wlanfw_cap_req_msg_v01_ei, &req);
2231 ath12k_warn(ab, "qmi failed to send target cap request, err = %d\n",
2236 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2238 ath12k_warn(ab, "qmi failed target cap request %d\n", ret);
2242 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2243 ath12k_warn(ab, "qmi targetcap req failed, result: %d, err: %d\n",
2244 resp.resp.result, resp.resp.error);
2249 if (resp.chip_info_valid) {
2250 ab->qmi.target.chip_id = resp.chip_info.chip_id;
2251 ab->qmi.target.chip_family = resp.chip_info.chip_family;
2254 if (resp.board_info_valid)
2255 ab->qmi.target.board_id = resp.board_info.board_id;
2257 ab->qmi.target.board_id = board_id;
2259 if (resp.soc_info_valid)
2260 ab->qmi.target.soc_id = resp.soc_info.soc_id;
2262 if (resp.fw_version_info_valid) {
2263 ab->qmi.target.fw_version = resp.fw_version_info.fw_version;
2264 strscpy(ab->qmi.target.fw_build_timestamp,
2265 resp.fw_version_info.fw_build_timestamp,
2266 sizeof(ab->qmi.target.fw_build_timestamp));
2269 if (resp.fw_build_id_valid)
2270 strscpy(ab->qmi.target.fw_build_id, resp.fw_build_id,
2271 sizeof(ab->qmi.target.fw_build_id));
2273 if (resp.dev_mem_info_valid) {
2274 for (i = 0; i < ATH12K_QMI_WLFW_MAX_DEV_MEM_NUM_V01; i++) {
2275 ab->qmi.dev_mem[i].start =
2276 resp.dev_mem[i].start;
2277 ab->qmi.dev_mem[i].size =
2278 resp.dev_mem[i].size;
2279 ath12k_dbg(ab, ATH12K_DBG_QMI,
2280 "devmem [%d] start ox%llx size %llu\n", i,
2281 ab->qmi.dev_mem[i].start,
2282 ab->qmi.dev_mem[i].size);
2286 if (resp.eeprom_caldata_read_timeout_valid) {
2287 ab->qmi.target.eeprom_caldata = resp.eeprom_caldata_read_timeout;
2288 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi cal data supported from eeprom\n");
2291 ath12k_info(ab, "chip_id 0x%x chip_family 0x%x board_id 0x%x soc_id 0x%x\n",
2292 ab->qmi.target.chip_id, ab->qmi.target.chip_family,
2293 ab->qmi.target.board_id, ab->qmi.target.soc_id);
2295 ath12k_info(ab, "fw_version 0x%x fw_build_timestamp %s fw_build_id %s",
2296 ab->qmi.target.fw_version,
2297 ab->qmi.target.fw_build_timestamp,
2298 ab->qmi.target.fw_build_id);
2304 static int ath12k_qmi_load_file_target_mem(struct ath12k_base *ab,
2305 const u8 *data, u32 len, u8 type)
2307 struct qmi_wlanfw_bdf_download_req_msg_v01 *req;
2308 struct qmi_wlanfw_bdf_download_resp_msg_v01 resp;
2309 struct qmi_txn txn = {};
2310 const u8 *temp = data;
2312 u32 remaining = len;
2314 req = kzalloc(sizeof(*req), GFP_KERNEL);
2317 memset(&resp, 0, sizeof(resp));
2321 req->file_id_valid = 1;
2322 req->file_id = ab->qmi.target.board_id;
2323 req->total_size_valid = 1;
2324 req->total_size = remaining;
2325 req->seg_id_valid = 1;
2326 req->data_valid = 1;
2327 req->bdf_type = type;
2328 req->bdf_type_valid = 1;
2332 if (remaining > QMI_WLANFW_MAX_DATA_SIZE_V01) {
2333 req->data_len = QMI_WLANFW_MAX_DATA_SIZE_V01;
2335 req->data_len = remaining;
2339 if (type == ATH12K_QMI_FILE_TYPE_EEPROM) {
2340 req->data_valid = 0;
2342 req->data_len = ATH12K_QMI_MAX_BDF_FILE_NAME_SIZE;
2344 memcpy(req->data, temp, req->data_len);
2347 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2348 qmi_wlanfw_bdf_download_resp_msg_v01_ei,
2353 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi bdf download req fixed addr type %d\n",
2356 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2357 QMI_WLANFW_BDF_DOWNLOAD_REQ_V01,
2358 QMI_WLANFW_BDF_DOWNLOAD_REQ_MSG_V01_MAX_LEN,
2359 qmi_wlanfw_bdf_download_req_msg_v01_ei, req);
2361 qmi_txn_cancel(&txn);
2365 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2369 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2370 ath12k_warn(ab, "qmi BDF download failed, result: %d, err: %d\n",
2371 resp.resp.result, resp.resp.error);
2376 if (type == ATH12K_QMI_FILE_TYPE_EEPROM) {
2379 remaining -= req->data_len;
2380 temp += req->data_len;
2382 ath12k_dbg(ab, ATH12K_DBG_QMI,
2383 "qmi bdf download request remaining %i\n",
2393 static int ath12k_qmi_load_bdf_qmi(struct ath12k_base *ab,
2394 enum ath12k_qmi_bdf_type type)
2396 struct device *dev = ab->dev;
2397 char filename[ATH12K_QMI_MAX_BDF_FILE_NAME_SIZE];
2398 const struct firmware *fw_entry;
2399 struct ath12k_board_data bd;
2400 u32 fw_size, file_type;
2404 memset(&bd, 0, sizeof(bd));
2407 case ATH12K_QMI_BDF_TYPE_ELF:
2408 ret = ath12k_core_fetch_bdf(ab, &bd);
2410 ath12k_warn(ab, "qmi failed to load bdf:\n");
2414 if (bd.len >= SELFMAG && memcmp(bd.data, ELFMAG, SELFMAG) == 0)
2415 type = ATH12K_QMI_BDF_TYPE_ELF;
2417 type = ATH12K_QMI_BDF_TYPE_BIN;
2420 case ATH12K_QMI_BDF_TYPE_REGDB:
2421 ret = ath12k_core_fetch_board_data_api_1(ab, &bd,
2422 ATH12K_REGDB_FILE_NAME);
2424 ath12k_warn(ab, "qmi failed to load regdb bin:\n");
2428 case ATH12K_QMI_BDF_TYPE_CALIBRATION:
2430 if (ab->qmi.target.eeprom_caldata) {
2431 file_type = ATH12K_QMI_FILE_TYPE_EEPROM;
2433 fw_size = ATH12K_QMI_MAX_BDF_FILE_NAME_SIZE;
2435 file_type = ATH12K_QMI_FILE_TYPE_CALDATA;
2437 /* cal-<bus>-<id>.bin */
2438 snprintf(filename, sizeof(filename), "cal-%s-%s.bin",
2439 ath12k_bus_str(ab->hif.bus), dev_name(dev));
2440 fw_entry = ath12k_core_firmware_request(ab, filename);
2441 if (!IS_ERR(fw_entry))
2444 fw_entry = ath12k_core_firmware_request(ab,
2445 ATH12K_DEFAULT_CAL_FILE);
2446 if (IS_ERR(fw_entry)) {
2447 ret = PTR_ERR(fw_entry);
2449 "qmi failed to load CAL data file:%s\n",
2455 fw_size = min_t(u32, ab->hw_params->fw.board_size,
2457 tmp = fw_entry->data;
2459 ret = ath12k_qmi_load_file_target_mem(ab, tmp, fw_size, file_type);
2461 ath12k_warn(ab, "qmi failed to load caldata\n");
2465 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi caldata downloaded: type: %u\n",
2469 if (!ab->qmi.target.eeprom_caldata)
2470 release_firmware(fw_entry);
2473 ath12k_warn(ab, "unknown file type for load %d", type);
2477 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi bdf_type %d\n", type);
2479 fw_size = min_t(u32, ab->hw_params->fw.board_size, bd.len);
2481 ret = ath12k_qmi_load_file_target_mem(ab, bd.data, fw_size, type);
2483 ath12k_warn(ab, "qmi failed to load bdf file\n");
2486 ath12k_core_free_bdf(ab, &bd);
2487 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi BDF download sequence completed\n");
2492 static int ath12k_qmi_m3_load(struct ath12k_base *ab)
2494 struct m3_mem_region *m3_mem = &ab->qmi.m3_mem;
2495 const struct firmware *fw;
2499 if (m3_mem->vaddr || m3_mem->size)
2502 fw = ath12k_core_firmware_request(ab, ATH12K_M3_FILE);
2505 ath12k_core_create_firmware_path(ab, ATH12K_M3_FILE,
2506 path, sizeof(path));
2507 ath12k_err(ab, "failed to load %s: %d\n", path, ret);
2511 m3_mem->vaddr = dma_alloc_coherent(ab->dev,
2512 fw->size, &m3_mem->paddr,
2514 if (!m3_mem->vaddr) {
2515 ath12k_err(ab, "failed to allocate memory for M3 with size %zu\n",
2517 release_firmware(fw);
2521 memcpy(m3_mem->vaddr, fw->data, fw->size);
2522 m3_mem->size = fw->size;
2523 release_firmware(fw);
2528 static void ath12k_qmi_m3_free(struct ath12k_base *ab)
2530 struct m3_mem_region *m3_mem = &ab->qmi.m3_mem;
2535 dma_free_coherent(ab->dev, m3_mem->size,
2536 m3_mem->vaddr, m3_mem->paddr);
2537 m3_mem->vaddr = NULL;
2540 static int ath12k_qmi_wlanfw_m3_info_send(struct ath12k_base *ab)
2542 struct m3_mem_region *m3_mem = &ab->qmi.m3_mem;
2543 struct qmi_wlanfw_m3_info_req_msg_v01 req;
2544 struct qmi_wlanfw_m3_info_resp_msg_v01 resp;
2545 struct qmi_txn txn = {};
2548 memset(&req, 0, sizeof(req));
2549 memset(&resp, 0, sizeof(resp));
2551 ret = ath12k_qmi_m3_load(ab);
2553 ath12k_err(ab, "failed to load m3 firmware: %d", ret);
2557 req.addr = m3_mem->paddr;
2558 req.size = m3_mem->size;
2560 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2561 qmi_wlanfw_m3_info_resp_msg_v01_ei, &resp);
2565 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2566 QMI_WLANFW_M3_INFO_REQ_V01,
2567 QMI_WLANFW_M3_INFO_REQ_MSG_V01_MAX_MSG_LEN,
2568 qmi_wlanfw_m3_info_req_msg_v01_ei, &req);
2570 ath12k_warn(ab, "qmi failed to send M3 information request, err = %d\n",
2575 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2577 ath12k_warn(ab, "qmi failed M3 information request %d\n", ret);
2581 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2582 ath12k_warn(ab, "qmi M3 info request failed, result: %d, err: %d\n",
2583 resp.resp.result, resp.resp.error);
2591 static int ath12k_qmi_wlanfw_mode_send(struct ath12k_base *ab,
2594 struct qmi_wlanfw_wlan_mode_req_msg_v01 req;
2595 struct qmi_wlanfw_wlan_mode_resp_msg_v01 resp;
2596 struct qmi_txn txn = {};
2599 memset(&req, 0, sizeof(req));
2600 memset(&resp, 0, sizeof(resp));
2603 req.hw_debug_valid = 1;
2606 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2607 qmi_wlanfw_wlan_mode_resp_msg_v01_ei, &resp);
2611 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2612 QMI_WLANFW_WLAN_MODE_REQ_V01,
2613 QMI_WLANFW_WLAN_MODE_REQ_MSG_V01_MAX_LEN,
2614 qmi_wlanfw_wlan_mode_req_msg_v01_ei, &req);
2616 ath12k_warn(ab, "qmi failed to send mode request, mode: %d, err = %d\n",
2621 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2623 if (mode == ATH12K_FIRMWARE_MODE_OFF && ret == -ENETRESET) {
2624 ath12k_warn(ab, "WLFW service is dis-connected\n");
2627 ath12k_warn(ab, "qmi failed set mode request, mode: %d, err = %d\n",
2632 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2633 ath12k_warn(ab, "Mode request failed, mode: %d, result: %d err: %d\n",
2634 mode, resp.resp.result, resp.resp.error);
2643 static int ath12k_qmi_wlanfw_wlan_cfg_send(struct ath12k_base *ab)
2645 struct qmi_wlanfw_wlan_cfg_req_msg_v01 *req;
2646 struct qmi_wlanfw_wlan_cfg_resp_msg_v01 resp;
2647 struct ce_pipe_config *ce_cfg;
2648 struct service_to_pipe *svc_cfg;
2649 struct qmi_txn txn = {};
2650 int ret = 0, pipe_num;
2652 ce_cfg = (struct ce_pipe_config *)ab->qmi.ce_cfg.tgt_ce;
2653 svc_cfg = (struct service_to_pipe *)ab->qmi.ce_cfg.svc_to_ce_map;
2655 req = kzalloc(sizeof(*req), GFP_KERNEL);
2659 memset(&resp, 0, sizeof(resp));
2661 req->host_version_valid = 1;
2662 strscpy(req->host_version, ATH12K_HOST_VERSION_STRING,
2663 sizeof(req->host_version));
2665 req->tgt_cfg_valid = 1;
2666 /* This is number of CE configs */
2667 req->tgt_cfg_len = ab->qmi.ce_cfg.tgt_ce_len;
2668 for (pipe_num = 0; pipe_num < req->tgt_cfg_len ; pipe_num++) {
2669 req->tgt_cfg[pipe_num].pipe_num = ce_cfg[pipe_num].pipenum;
2670 req->tgt_cfg[pipe_num].pipe_dir = ce_cfg[pipe_num].pipedir;
2671 req->tgt_cfg[pipe_num].nentries = ce_cfg[pipe_num].nentries;
2672 req->tgt_cfg[pipe_num].nbytes_max = ce_cfg[pipe_num].nbytes_max;
2673 req->tgt_cfg[pipe_num].flags = ce_cfg[pipe_num].flags;
2676 req->svc_cfg_valid = 1;
2677 /* This is number of Service/CE configs */
2678 req->svc_cfg_len = ab->qmi.ce_cfg.svc_to_ce_map_len;
2679 for (pipe_num = 0; pipe_num < req->svc_cfg_len; pipe_num++) {
2680 req->svc_cfg[pipe_num].service_id = svc_cfg[pipe_num].service_id;
2681 req->svc_cfg[pipe_num].pipe_dir = svc_cfg[pipe_num].pipedir;
2682 req->svc_cfg[pipe_num].pipe_num = svc_cfg[pipe_num].pipenum;
2685 /* set shadow v3 configuration */
2686 if (ab->hw_params->supports_shadow_regs) {
2687 req->shadow_reg_v3_valid = 1;
2688 req->shadow_reg_v3_len = min_t(u32,
2689 ab->qmi.ce_cfg.shadow_reg_v3_len,
2690 QMI_WLANFW_MAX_NUM_SHADOW_REG_V3_V01);
2691 memcpy(&req->shadow_reg_v3, ab->qmi.ce_cfg.shadow_reg_v3,
2692 sizeof(u32) * req->shadow_reg_v3_len);
2694 req->shadow_reg_v3_valid = 0;
2697 ret = qmi_txn_init(&ab->qmi.handle, &txn,
2698 qmi_wlanfw_wlan_cfg_resp_msg_v01_ei, &resp);
2702 ret = qmi_send_request(&ab->qmi.handle, NULL, &txn,
2703 QMI_WLANFW_WLAN_CFG_REQ_V01,
2704 QMI_WLANFW_WLAN_CFG_REQ_MSG_V01_MAX_LEN,
2705 qmi_wlanfw_wlan_cfg_req_msg_v01_ei, req);
2707 ath12k_warn(ab, "qmi failed to send wlan config request, err = %d\n",
2712 ret = qmi_txn_wait(&txn, msecs_to_jiffies(ATH12K_QMI_WLANFW_TIMEOUT_MS));
2714 ath12k_warn(ab, "qmi failed wlan config request, err = %d\n", ret);
2718 if (resp.resp.result != QMI_RESULT_SUCCESS_V01) {
2719 ath12k_warn(ab, "qmi wlan config request failed, result: %d, err: %d\n",
2720 resp.resp.result, resp.resp.error);
2730 void ath12k_qmi_firmware_stop(struct ath12k_base *ab)
2734 ret = ath12k_qmi_wlanfw_mode_send(ab, ATH12K_FIRMWARE_MODE_OFF);
2736 ath12k_warn(ab, "qmi failed to send wlan mode off\n");
2741 int ath12k_qmi_firmware_start(struct ath12k_base *ab,
2746 ret = ath12k_qmi_wlanfw_wlan_cfg_send(ab);
2748 ath12k_warn(ab, "qmi failed to send wlan cfg:%d\n", ret);
2752 ret = ath12k_qmi_wlanfw_mode_send(ab, mode);
2754 ath12k_warn(ab, "qmi failed to send wlan fw mode:%d\n", ret);
2762 ath12k_qmi_driver_event_post(struct ath12k_qmi *qmi,
2763 enum ath12k_qmi_event_type type,
2766 struct ath12k_qmi_driver_event *event;
2768 event = kzalloc(sizeof(*event), GFP_ATOMIC);
2775 spin_lock(&qmi->event_lock);
2776 list_add_tail(&event->list, &qmi->event_list);
2777 spin_unlock(&qmi->event_lock);
2779 queue_work(qmi->event_wq, &qmi->event_work);
2784 static int ath12k_qmi_event_server_arrive(struct ath12k_qmi *qmi)
2786 struct ath12k_base *ab = qmi->ab;
2789 ret = ath12k_qmi_fw_ind_register_send(ab);
2791 ath12k_warn(ab, "qmi failed to send FW indication QMI:%d\n", ret);
2795 ret = ath12k_qmi_host_cap_send(ab);
2797 ath12k_warn(ab, "qmi failed to send host cap QMI:%d\n", ret);
2804 static int ath12k_qmi_event_mem_request(struct ath12k_qmi *qmi)
2806 struct ath12k_base *ab = qmi->ab;
2809 ret = ath12k_qmi_respond_fw_mem_request(ab);
2811 ath12k_warn(ab, "qmi failed to respond fw mem req:%d\n", ret);
2818 static int ath12k_qmi_event_load_bdf(struct ath12k_qmi *qmi)
2820 struct ath12k_base *ab = qmi->ab;
2823 ret = ath12k_qmi_request_target_cap(ab);
2825 ath12k_warn(ab, "qmi failed to req target capabilities:%d\n", ret);
2829 ret = ath12k_qmi_load_bdf_qmi(ab, ATH12K_QMI_BDF_TYPE_REGDB);
2831 ath12k_warn(ab, "qmi failed to load regdb file:%d\n", ret);
2835 ret = ath12k_qmi_load_bdf_qmi(ab, ATH12K_QMI_BDF_TYPE_ELF);
2837 ath12k_warn(ab, "qmi failed to load board data file:%d\n", ret);
2841 if (ab->hw_params->download_calib) {
2842 ret = ath12k_qmi_load_bdf_qmi(ab, ATH12K_QMI_BDF_TYPE_CALIBRATION);
2844 ath12k_warn(ab, "qmi failed to load calibrated data :%d\n", ret);
2847 ret = ath12k_qmi_wlanfw_m3_info_send(ab);
2849 ath12k_warn(ab, "qmi failed to send m3 info req:%d\n", ret);
2856 static void ath12k_qmi_msg_mem_request_cb(struct qmi_handle *qmi_hdl,
2857 struct sockaddr_qrtr *sq,
2858 struct qmi_txn *txn,
2861 struct ath12k_qmi *qmi = container_of(qmi_hdl, struct ath12k_qmi, handle);
2862 struct ath12k_base *ab = qmi->ab;
2863 const struct qmi_wlanfw_request_mem_ind_msg_v01 *msg = data;
2866 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi firmware request memory request\n");
2868 if (msg->mem_seg_len == 0 ||
2869 msg->mem_seg_len > ATH12K_QMI_WLANFW_MAX_NUM_MEM_SEG_V01)
2870 ath12k_warn(ab, "Invalid memory segment length: %u\n",
2873 ab->qmi.mem_seg_count = msg->mem_seg_len;
2875 for (i = 0; i < qmi->mem_seg_count ; i++) {
2876 ab->qmi.target_mem[i].type = msg->mem_seg[i].type;
2877 ab->qmi.target_mem[i].size = msg->mem_seg[i].size;
2878 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi mem seg type %d size %d\n",
2879 msg->mem_seg[i].type, msg->mem_seg[i].size);
2882 ret = ath12k_qmi_alloc_target_mem_chunk(ab);
2884 ath12k_warn(ab, "qmi failed to alloc target memory: %d\n",
2889 ath12k_qmi_driver_event_post(qmi, ATH12K_QMI_EVENT_REQUEST_MEM, NULL);
2892 static void ath12k_qmi_msg_mem_ready_cb(struct qmi_handle *qmi_hdl,
2893 struct sockaddr_qrtr *sq,
2894 struct qmi_txn *txn,
2895 const void *decoded)
2897 struct ath12k_qmi *qmi = container_of(qmi_hdl, struct ath12k_qmi, handle);
2898 struct ath12k_base *ab = qmi->ab;
2900 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi firmware memory ready indication\n");
2901 ath12k_qmi_driver_event_post(qmi, ATH12K_QMI_EVENT_FW_MEM_READY, NULL);
2904 static void ath12k_qmi_msg_fw_ready_cb(struct qmi_handle *qmi_hdl,
2905 struct sockaddr_qrtr *sq,
2906 struct qmi_txn *txn,
2907 const void *decoded)
2909 struct ath12k_qmi *qmi = container_of(qmi_hdl, struct ath12k_qmi, handle);
2910 struct ath12k_base *ab = qmi->ab;
2912 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi firmware ready\n");
2913 ath12k_qmi_driver_event_post(qmi, ATH12K_QMI_EVENT_FW_READY, NULL);
2916 static const struct qmi_msg_handler ath12k_qmi_msg_handlers[] = {
2918 .type = QMI_INDICATION,
2919 .msg_id = QMI_WLFW_REQUEST_MEM_IND_V01,
2920 .ei = qmi_wlanfw_request_mem_ind_msg_v01_ei,
2921 .decoded_size = sizeof(struct qmi_wlanfw_request_mem_ind_msg_v01),
2922 .fn = ath12k_qmi_msg_mem_request_cb,
2925 .type = QMI_INDICATION,
2926 .msg_id = QMI_WLFW_FW_MEM_READY_IND_V01,
2927 .ei = qmi_wlanfw_mem_ready_ind_msg_v01_ei,
2928 .decoded_size = sizeof(struct qmi_wlanfw_fw_mem_ready_ind_msg_v01),
2929 .fn = ath12k_qmi_msg_mem_ready_cb,
2932 .type = QMI_INDICATION,
2933 .msg_id = QMI_WLFW_FW_READY_IND_V01,
2934 .ei = qmi_wlanfw_fw_ready_ind_msg_v01_ei,
2935 .decoded_size = sizeof(struct qmi_wlanfw_fw_ready_ind_msg_v01),
2936 .fn = ath12k_qmi_msg_fw_ready_cb,
2940 static int ath12k_qmi_ops_new_server(struct qmi_handle *qmi_hdl,
2941 struct qmi_service *service)
2943 struct ath12k_qmi *qmi = container_of(qmi_hdl, struct ath12k_qmi, handle);
2944 struct ath12k_base *ab = qmi->ab;
2945 struct sockaddr_qrtr *sq = &qmi->sq;
2948 sq->sq_family = AF_QIPCRTR;
2949 sq->sq_node = service->node;
2950 sq->sq_port = service->port;
2952 ret = kernel_connect(qmi_hdl->sock, (struct sockaddr *)sq,
2955 ath12k_warn(ab, "qmi failed to connect to remote service %d\n", ret);
2959 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi wifi fw qmi service connected\n");
2960 ath12k_qmi_driver_event_post(qmi, ATH12K_QMI_EVENT_SERVER_ARRIVE, NULL);
2965 static void ath12k_qmi_ops_del_server(struct qmi_handle *qmi_hdl,
2966 struct qmi_service *service)
2968 struct ath12k_qmi *qmi = container_of(qmi_hdl, struct ath12k_qmi, handle);
2969 struct ath12k_base *ab = qmi->ab;
2971 ath12k_dbg(ab, ATH12K_DBG_QMI, "qmi wifi fw del server\n");
2972 ath12k_qmi_driver_event_post(qmi, ATH12K_QMI_EVENT_SERVER_EXIT, NULL);
2975 static const struct qmi_ops ath12k_qmi_ops = {
2976 .new_server = ath12k_qmi_ops_new_server,
2977 .del_server = ath12k_qmi_ops_del_server,
2980 static void ath12k_qmi_driver_event_work(struct work_struct *work)
2982 struct ath12k_qmi *qmi = container_of(work, struct ath12k_qmi,
2984 struct ath12k_qmi_driver_event *event;
2985 struct ath12k_base *ab = qmi->ab;
2988 spin_lock(&qmi->event_lock);
2989 while (!list_empty(&qmi->event_list)) {
2990 event = list_first_entry(&qmi->event_list,
2991 struct ath12k_qmi_driver_event, list);
2992 list_del(&event->list);
2993 spin_unlock(&qmi->event_lock);
2995 if (test_bit(ATH12K_FLAG_UNREGISTERING, &ab->dev_flags))
2998 switch (event->type) {
2999 case ATH12K_QMI_EVENT_SERVER_ARRIVE:
3000 ret = ath12k_qmi_event_server_arrive(qmi);
3002 set_bit(ATH12K_FLAG_QMI_FAIL, &ab->dev_flags);
3004 case ATH12K_QMI_EVENT_SERVER_EXIT:
3005 set_bit(ATH12K_FLAG_CRASH_FLUSH, &ab->dev_flags);
3006 set_bit(ATH12K_FLAG_RECOVERY, &ab->dev_flags);
3008 case ATH12K_QMI_EVENT_REQUEST_MEM:
3009 ret = ath12k_qmi_event_mem_request(qmi);
3011 set_bit(ATH12K_FLAG_QMI_FAIL, &ab->dev_flags);
3013 case ATH12K_QMI_EVENT_FW_MEM_READY:
3014 ret = ath12k_qmi_event_load_bdf(qmi);
3016 set_bit(ATH12K_FLAG_QMI_FAIL, &ab->dev_flags);
3018 case ATH12K_QMI_EVENT_FW_READY:
3019 clear_bit(ATH12K_FLAG_QMI_FAIL, &ab->dev_flags);
3020 if (test_bit(ATH12K_FLAG_REGISTERED, &ab->dev_flags)) {
3021 ath12k_hal_dump_srng_stats(ab);
3022 queue_work(ab->workqueue, &ab->restart_work);
3026 clear_bit(ATH12K_FLAG_CRASH_FLUSH,
3028 clear_bit(ATH12K_FLAG_RECOVERY, &ab->dev_flags);
3029 ath12k_core_qmi_firmware_ready(ab);
3030 set_bit(ATH12K_FLAG_REGISTERED, &ab->dev_flags);
3034 ath12k_warn(ab, "invalid event type: %d", event->type);
3040 spin_lock(&qmi->event_lock);
3042 spin_unlock(&qmi->event_lock);
3045 int ath12k_qmi_init_service(struct ath12k_base *ab)
3049 memset(&ab->qmi.target, 0, sizeof(struct target_info));
3050 memset(&ab->qmi.target_mem, 0, sizeof(struct target_mem_chunk));
3053 ab->qmi.target_mem_mode = ATH12K_QMI_TARGET_MEM_MODE_DEFAULT;
3054 ret = qmi_handle_init(&ab->qmi.handle, ATH12K_QMI_RESP_LEN_MAX,
3055 &ath12k_qmi_ops, ath12k_qmi_msg_handlers);
3057 ath12k_warn(ab, "failed to initialize qmi handle\n");
3061 ab->qmi.event_wq = alloc_ordered_workqueue("ath12k_qmi_driver_event", 0);
3062 if (!ab->qmi.event_wq) {
3063 ath12k_err(ab, "failed to allocate workqueue\n");
3067 INIT_LIST_HEAD(&ab->qmi.event_list);
3068 spin_lock_init(&ab->qmi.event_lock);
3069 INIT_WORK(&ab->qmi.event_work, ath12k_qmi_driver_event_work);
3071 ret = qmi_add_lookup(&ab->qmi.handle, ATH12K_QMI_WLFW_SERVICE_ID_V01,
3072 ATH12K_QMI_WLFW_SERVICE_VERS_V01,
3073 ab->qmi.service_ins_id);
3075 ath12k_warn(ab, "failed to add qmi lookup\n");
3076 destroy_workqueue(ab->qmi.event_wq);
3083 void ath12k_qmi_deinit_service(struct ath12k_base *ab)
3085 qmi_handle_release(&ab->qmi.handle);
3086 cancel_work_sync(&ab->qmi.event_work);
3087 destroy_workqueue(ab->qmi.event_wq);
3088 ath12k_qmi_m3_free(ab);
3089 ath12k_qmi_free_target_mem_chunk(ab);