1 /*
2  * Copyright (c) 2017-2021 The Linux Foundation. All rights reserved.
3  * Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved.
4  *
5  * Permission to use, copy, modify, and/or distribute this software for
6  * any purpose with or without fee is hereby granted, provided that the
7  * above copyright notice and this permission notice appear in all
8  * copies.
9  *
10  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17  * PERFORMANCE OF THIS SOFTWARE.
18  */
19 
20 /**
21  * DOC: Implement API's specific to Regulatory component.
22  */
23 
24 #include <qdf_status.h>
25 #include <qdf_module.h>
26 #include <wmi_unified_api.h>
27 #include <wmi_unified_priv.h>
28 #include <wmi_unified_reg_api.h>
29 
wmi_extract_reg_chan_list_update_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct cur_regulatory_info * reg_info,uint32_t len)30 QDF_STATUS wmi_extract_reg_chan_list_update_event(
31 		wmi_unified_t wmi_handle,
32 		uint8_t *evt_buf,
33 		struct cur_regulatory_info *reg_info,
34 		uint32_t len)
35 {
36 	if (wmi_handle && wmi_handle->ops->extract_reg_chan_list_update_event)
37 		return wmi_handle->ops->extract_reg_chan_list_update_event
38 			(wmi_handle,
39 			 evt_buf, reg_info, len);
40 
41 	return QDF_STATUS_E_FAILURE;
42 }
43 qdf_export_symbol(wmi_extract_reg_chan_list_update_event);
44 
45 #ifdef CONFIG_BAND_6GHZ
wmi_extract_reg_chan_list_ext_update_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct cur_regulatory_info * reg_info,uint32_t len)46 QDF_STATUS wmi_extract_reg_chan_list_ext_update_event(
47 		wmi_unified_t wmi_handle,
48 		uint8_t *evt_buf,
49 		struct cur_regulatory_info *reg_info,
50 		uint32_t len)
51 {
52 	if (wmi_handle &&
53 	    wmi_handle->ops->extract_reg_chan_list_ext_update_event)
54 		return wmi_handle->ops->extract_reg_chan_list_ext_update_event
55 					(wmi_handle, evt_buf, reg_info, len);
56 
57 	return QDF_STATUS_E_FAILURE;
58 }
59 
60 qdf_export_symbol(wmi_extract_reg_chan_list_ext_update_event);
61 
62 #ifdef CONFIG_AFC_SUPPORT
wmi_extract_afc_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct afc_regulatory_info * afc_info,uint32_t len)63 QDF_STATUS wmi_extract_afc_event(wmi_unified_t wmi_handle,
64 				 uint8_t *evt_buf,
65 				 struct afc_regulatory_info *afc_info,
66 				 uint32_t len)
67 {
68 	if (wmi_handle &&
69 	    wmi_handle->ops->extract_afc_event)
70 		return wmi_handle->ops->extract_afc_event(wmi_handle, evt_buf,
71 							  afc_info, len);
72 
73 	return QDF_STATUS_E_FAILURE;
74 }
75 
76 qdf_export_symbol(wmi_extract_afc_event);
77 #endif
78 #endif
79 
80 /*
81  * wmi_unified_send_start_11d_scan_cmd() - start 11d scan
82  * @wmi_handle: wmi handle
83  * @start_11d_scan: pointer to 11d scan start req.
84  *
85  * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
86  */
wmi_unified_send_start_11d_scan_cmd(wmi_unified_t wmi_handle,struct reg_start_11d_scan_req * start_11d_scan)87 QDF_STATUS wmi_unified_send_start_11d_scan_cmd(wmi_unified_t wmi_handle,
88 		struct reg_start_11d_scan_req *start_11d_scan)
89 {
90 	if (wmi_handle->ops->send_start_11d_scan_cmd)
91 		return wmi_handle->ops->send_start_11d_scan_cmd(wmi_handle,
92 				start_11d_scan);
93 
94 	return QDF_STATUS_E_FAILURE;
95 }
96 qdf_export_symbol(wmi_unified_send_start_11d_scan_cmd);
97 
98 /*
99  * wmi_unified_send_stop_11d_scan_cmd() - stop 11d scan
100  * @wmi_handle: wmi handle
101  * @stop_11d_scan: pointer to 11d scan stop req.
102  *
103  * Return: QDF_STATUS_SUCCESS on success, QDF_STATUS_E_** on error
104  */
wmi_unified_send_stop_11d_scan_cmd(wmi_unified_t wmi_handle,struct reg_stop_11d_scan_req * stop_11d_scan)105 QDF_STATUS wmi_unified_send_stop_11d_scan_cmd(wmi_unified_t wmi_handle,
106 		struct reg_stop_11d_scan_req *stop_11d_scan)
107 {
108 	if (wmi_handle->ops->send_stop_11d_scan_cmd)
109 		return wmi_handle->ops->send_stop_11d_scan_cmd(wmi_handle,
110 				stop_11d_scan);
111 
112 	return QDF_STATUS_E_FAILURE;
113 }
114 qdf_export_symbol(wmi_unified_send_stop_11d_scan_cmd);
115 
wmi_extract_reg_11d_new_cc_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct reg_11d_new_country * reg_11d_new_cc,uint32_t len)116 QDF_STATUS wmi_extract_reg_11d_new_cc_event(
117 		wmi_unified_t wmi_handle,
118 		uint8_t *evt_buf,
119 		struct reg_11d_new_country *reg_11d_new_cc,
120 		uint32_t len)
121 {
122 	if (wmi_handle && wmi_handle->ops->extract_reg_11d_new_country_event)
123 		return wmi_handle->ops->extract_reg_11d_new_country_event(
124 				wmi_handle, evt_buf, reg_11d_new_cc, len);
125 
126 	return QDF_STATUS_E_FAILURE;
127 }
128 qdf_export_symbol(wmi_extract_reg_11d_new_cc_event);
129 
wmi_unified_set_user_country_code_cmd_send(wmi_unified_t wmi_handle,uint8_t pdev_id,struct cc_regdmn_s * rd)130 QDF_STATUS wmi_unified_set_user_country_code_cmd_send(
131 		wmi_unified_t wmi_handle,
132 		uint8_t pdev_id, struct cc_regdmn_s *rd)
133 {
134 	if (wmi_handle->ops->send_user_country_code_cmd)
135 		return wmi_handle->ops->send_user_country_code_cmd(
136 				wmi_handle, pdev_id, rd);
137 
138 	return QDF_STATUS_E_FAILURE;
139 }
140 qdf_export_symbol(wmi_unified_set_user_country_code_cmd_send);
141 
wmi_extract_reg_ch_avoid_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct ch_avoid_ind_type * ch_avoid_ind,uint32_t len)142 QDF_STATUS wmi_extract_reg_ch_avoid_event(
143 		wmi_unified_t wmi_handle,
144 		uint8_t *evt_buf,
145 		struct ch_avoid_ind_type *ch_avoid_ind,
146 		uint32_t len)
147 {
148 	if (wmi_handle && wmi_handle->ops->extract_reg_ch_avoid_event)
149 		return wmi_handle->ops->extract_reg_ch_avoid_event(
150 				wmi_handle, evt_buf, ch_avoid_ind, len);
151 
152 	return QDF_STATUS_E_FAILURE;
153 }
154 qdf_export_symbol(wmi_extract_reg_ch_avoid_event);
155 
wmi_extract_tgtr2p_table_event(wmi_unified_t wmi_handle,uint8_t * evt_buf,struct r2p_table_update_status_obj * update_status,uint32_t len)156 QDF_STATUS wmi_extract_tgtr2p_table_event(
157 		wmi_unified_t wmi_handle,
158 		uint8_t *evt_buf,
159 		struct r2p_table_update_status_obj *update_status,
160 		uint32_t len)
161 {
162 	if (wmi_handle &&
163 	    wmi_handle->ops->extract_tgtr2p_table_event)
164 		return wmi_handle->ops->extract_tgtr2p_table_event(
165 				wmi_handle, evt_buf, update_status, len);
166 
167 	return QDF_STATUS_E_FAILURE;
168 }
169 
170 qdf_export_symbol(wmi_extract_tgtr2p_table_event);
171