xref: /wlan-driver/qcacld-3.0/core/cds/inc/cds_api.h (revision 5113495b16420b49004c444715d2daae2066e7dc)
1*5113495bSYour Name /*
2*5113495bSYour Name  * Copyright (c) 2014-2021 The Linux Foundation. All rights reserved.
3*5113495bSYour Name  * Copyright (c) 2021-2023 Qualcomm Innovation Center, Inc. All rights reserved.
4*5113495bSYour Name  *
5*5113495bSYour Name  * Permission to use, copy, modify, and/or distribute this software for
6*5113495bSYour Name  * any purpose with or without fee is hereby granted, provided that the
7*5113495bSYour Name  * above copyright notice and this permission notice appear in all
8*5113495bSYour Name  * copies.
9*5113495bSYour Name  *
10*5113495bSYour Name  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
11*5113495bSYour Name  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
12*5113495bSYour Name  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
13*5113495bSYour Name  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
14*5113495bSYour Name  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
15*5113495bSYour Name  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
16*5113495bSYour Name  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*5113495bSYour Name  * PERFORMANCE OF THIS SOFTWARE.
18*5113495bSYour Name  */
19*5113495bSYour Name 
20*5113495bSYour Name #if !defined(__CDS_API_H)
21*5113495bSYour Name #define __CDS_API_H
22*5113495bSYour Name 
23*5113495bSYour Name /**
24*5113495bSYour Name  * DOC:  cds_api.h
25*5113495bSYour Name  *
26*5113495bSYour Name  * Connectivity driver services public API
27*5113495bSYour Name  *
28*5113495bSYour Name  */
29*5113495bSYour Name 
30*5113495bSYour Name #include <qdf_types.h>
31*5113495bSYour Name #include <qdf_status.h>
32*5113495bSYour Name #include <qdf_mem.h>
33*5113495bSYour Name #include <qdf_debugfs.h>
34*5113495bSYour Name #include <qdf_list.h>
35*5113495bSYour Name #include <qdf_trace.h>
36*5113495bSYour Name #include <qdf_event.h>
37*5113495bSYour Name #include <qdf_lock.h>
38*5113495bSYour Name #include "qdf_platform.h"
39*5113495bSYour Name #include "qdf_cpuhp.h"
40*5113495bSYour Name #include <wlan_cmn.h>
41*5113495bSYour Name #include "reg_services_public_struct.h"
42*5113495bSYour Name #include <cds_reg_service.h>
43*5113495bSYour Name #include <cds_packet.h>
44*5113495bSYour Name #include <cds_sched.h>
45*5113495bSYour Name #include <qdf_threads.h>
46*5113495bSYour Name #include <qdf_mc_timer.h>
47*5113495bSYour Name #include <wlan_objmgr_psoc_obj.h>
48*5113495bSYour Name #include <cdp_txrx_handle.h>
49*5113495bSYour Name 
50*5113495bSYour Name /* The ini gReorderOffloadSupported is deprecated. So, defining a new macro
51*5113495bSYour Name  * DP_REORDER_OFFLOAD_SUPPORT with the ini's default value.
52*5113495bSYour Name  */
53*5113495bSYour Name #define DP_REORDER_OFFLOAD_SUPPORT (1)
54*5113495bSYour Name 
55*5113495bSYour Name /* Amount of time to wait for WMA to perform an asynchronous activity.
56*5113495bSYour Name  * This value should be larger than the timeout used by WMI to wait for
57*5113495bSYour Name  * a response from target
58*5113495bSYour Name  */
59*5113495bSYour Name #define CDS_WMA_TIMEOUT  (15000)
60*5113495bSYour Name 
61*5113495bSYour Name /**
62*5113495bSYour Name  * enum cds_driver_state - Driver state
63*5113495bSYour Name  * @CDS_DRIVER_STATE_UNINITIALIZED: Driver is in uninitialized state.
64*5113495bSYour Name  * @CDS_DRIVER_STATE_LOADED: Driver is loaded and functional.
65*5113495bSYour Name  * @CDS_DRIVER_STATE_LOADING: Driver probe is in progress.
66*5113495bSYour Name  * @CDS_DRIVER_STATE_UNLOADING: Driver remove is in progress.
67*5113495bSYour Name  * @CDS_DRIVER_STATE_RECOVERING: Recovery in progress.
68*5113495bSYour Name  * @CDS_DRIVER_STATE_BAD: Driver in bad state.
69*5113495bSYour Name  * @CDS_DRIVER_STATE_FW_READY: Driver Firmware ready
70*5113495bSYour Name  * @CDS_DRIVER_STATE_MODULE_STOP: Module stop in progress or done.
71*5113495bSYour Name  * @CDS_DRIVER_STATE_ASSERTING_TARGET: Driver assert target in progress.
72*5113495bSYour Name  * @CDS_DRIVER_STATE_SYS_REBOOTING: System reboot in progress.
73*5113495bSYour Name  */
74*5113495bSYour Name enum cds_driver_state {
75*5113495bSYour Name 	CDS_DRIVER_STATE_UNINITIALIZED          = 0,
76*5113495bSYour Name 	CDS_DRIVER_STATE_LOADED                 = BIT(0),
77*5113495bSYour Name 	CDS_DRIVER_STATE_LOADING                = BIT(1),
78*5113495bSYour Name 	CDS_DRIVER_STATE_UNLOADING              = BIT(2),
79*5113495bSYour Name 	CDS_DRIVER_STATE_RECOVERING             = BIT(3),
80*5113495bSYour Name 	CDS_DRIVER_STATE_BAD                    = BIT(4),
81*5113495bSYour Name 	CDS_DRIVER_STATE_FW_READY               = BIT(5),
82*5113495bSYour Name 	CDS_DRIVER_STATE_MODULE_STOP            = BIT(6),
83*5113495bSYour Name 	CDS_DRIVER_STATE_ASSERTING_TARGET       = BIT(7),
84*5113495bSYour Name 	CDS_DRIVER_STATE_SYS_REBOOTING          = BIT(8),
85*5113495bSYour Name };
86*5113495bSYour Name 
87*5113495bSYour Name /**
88*5113495bSYour Name  * struct cds_vdev_dp_stats - vdev stats populated from DP
89*5113495bSYour Name  * @tx_retries: packet number of successfully transmitted after more
90*5113495bSYour Name  *              than one retransmission attempt
91*5113495bSYour Name  * @tx_retries_mpdu: mpdu number of successfully transmitted after more
92*5113495bSYour Name  *              than one retransmission attempt
93*5113495bSYour Name  * @tx_mpdu_success_with_retries: Number of MPDU transmission retries done
94*5113495bSYour Name  *				  in case of successful transmission.
95*5113495bSYour Name  */
96*5113495bSYour Name struct cds_vdev_dp_stats {
97*5113495bSYour Name 	uint32_t tx_retries;
98*5113495bSYour Name 	uint32_t tx_retries_mpdu;
99*5113495bSYour Name 	uint32_t tx_mpdu_success_with_retries;
100*5113495bSYour Name };
101*5113495bSYour Name 
102*5113495bSYour Name #define __CDS_IS_DRIVER_STATE(_state, _mask) (((_state) & (_mask)) == (_mask))
103*5113495bSYour Name 
104*5113495bSYour Name void cds_set_driver_state(enum cds_driver_state);
105*5113495bSYour Name void cds_clear_driver_state(enum cds_driver_state);
106*5113495bSYour Name enum cds_driver_state cds_get_driver_state(void);
107*5113495bSYour Name 
108*5113495bSYour Name /**
109*5113495bSYour Name  * cds_is_driver_loading() - Is driver load in progress
110*5113495bSYour Name  *
111*5113495bSYour Name  * Return: true if driver is loading and false otherwise.
112*5113495bSYour Name  */
cds_is_driver_loading(void)113*5113495bSYour Name static inline bool cds_is_driver_loading(void)
114*5113495bSYour Name {
115*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
116*5113495bSYour Name 
117*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_LOADING);
118*5113495bSYour Name }
119*5113495bSYour Name 
120*5113495bSYour Name /**
121*5113495bSYour Name  * cds_is_driver_unloading() - Is driver unload in progress
122*5113495bSYour Name  *
123*5113495bSYour Name  * Return: true if driver is unloading and false otherwise.
124*5113495bSYour Name  */
cds_is_driver_unloading(void)125*5113495bSYour Name static inline bool cds_is_driver_unloading(void)
126*5113495bSYour Name {
127*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
128*5113495bSYour Name 
129*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_UNLOADING);
130*5113495bSYour Name }
131*5113495bSYour Name 
132*5113495bSYour Name /**
133*5113495bSYour Name  * cds_is_driver_recovering() - Is recovery in progress
134*5113495bSYour Name  *
135*5113495bSYour Name  * Return: true if recovery in progress  and false otherwise.
136*5113495bSYour Name  */
cds_is_driver_recovering(void)137*5113495bSYour Name static inline bool cds_is_driver_recovering(void)
138*5113495bSYour Name {
139*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
140*5113495bSYour Name 
141*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_RECOVERING);
142*5113495bSYour Name }
143*5113495bSYour Name 
144*5113495bSYour Name /**
145*5113495bSYour Name  * cds_is_driver_in_bad_state() - is driver in bad state
146*5113495bSYour Name  *
147*5113495bSYour Name  * Return: true if driver is in bad state and false otherwise.
148*5113495bSYour Name  */
cds_is_driver_in_bad_state(void)149*5113495bSYour Name static inline bool cds_is_driver_in_bad_state(void)
150*5113495bSYour Name {
151*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
152*5113495bSYour Name 
153*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_BAD);
154*5113495bSYour Name }
155*5113495bSYour Name 
156*5113495bSYour Name /**
157*5113495bSYour Name  * cds_is_load_or_unload_in_progress() - Is driver load OR unload in progress
158*5113495bSYour Name  *
159*5113495bSYour Name  * Return: true if driver is loading OR unloading and false otherwise.
160*5113495bSYour Name  */
cds_is_load_or_unload_in_progress(void)161*5113495bSYour Name static inline bool cds_is_load_or_unload_in_progress(void)
162*5113495bSYour Name {
163*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
164*5113495bSYour Name 
165*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_LOADING) ||
166*5113495bSYour Name 		__CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_UNLOADING);
167*5113495bSYour Name }
168*5113495bSYour Name 
169*5113495bSYour Name /**
170*5113495bSYour Name  * cds_is_target_ready() - Is target is in ready state
171*5113495bSYour Name  *
172*5113495bSYour Name  * Return: true if target is in ready state and false otherwise.
173*5113495bSYour Name  */
cds_is_target_ready(void)174*5113495bSYour Name static inline bool cds_is_target_ready(void)
175*5113495bSYour Name {
176*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
177*5113495bSYour Name 
178*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_FW_READY);
179*5113495bSYour Name }
180*5113495bSYour Name 
181*5113495bSYour Name /**
182*5113495bSYour Name  * cds_is_driver_state_module_stop - Is module stop is in-progress or done
183*5113495bSYour Name  *
184*5113495bSYour Name  * Return: true if driver state is module stop and false otherwise.
185*5113495bSYour Name  */
cds_is_driver_state_module_stop(void)186*5113495bSYour Name static inline bool cds_is_driver_state_module_stop(void)
187*5113495bSYour Name {
188*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
189*5113495bSYour Name 
190*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_MODULE_STOP);
191*5113495bSYour Name }
192*5113495bSYour Name 
193*5113495bSYour Name /**
194*5113495bSYour Name  * cds_set_recovery_in_progress() - Set recovery in progress
195*5113495bSYour Name  * @value: value to set
196*5113495bSYour Name  *
197*5113495bSYour Name  * Return: none
198*5113495bSYour Name  */
cds_set_recovery_in_progress(uint8_t value)199*5113495bSYour Name static inline void cds_set_recovery_in_progress(uint8_t value)
200*5113495bSYour Name {
201*5113495bSYour Name 	if (value)
202*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_RECOVERING);
203*5113495bSYour Name 	else
204*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_RECOVERING);
205*5113495bSYour Name }
206*5113495bSYour Name 
207*5113495bSYour Name /**
208*5113495bSYour Name  * cds_set_driver_in_bad_state() - Set driver state
209*5113495bSYour Name  * @value: value to set
210*5113495bSYour Name  *
211*5113495bSYour Name  * Return: none
212*5113495bSYour Name  */
cds_set_driver_in_bad_state(uint8_t value)213*5113495bSYour Name static inline void cds_set_driver_in_bad_state(uint8_t value)
214*5113495bSYour Name {
215*5113495bSYour Name 	if (value)
216*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_BAD);
217*5113495bSYour Name 	else
218*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_BAD);
219*5113495bSYour Name }
220*5113495bSYour Name 
221*5113495bSYour Name /**
222*5113495bSYour Name  * cds_set_target_ready() - Set target ready state
223*5113495bSYour Name  * @value: value to set
224*5113495bSYour Name  *
225*5113495bSYour Name  * Return: none
226*5113495bSYour Name  */
cds_set_target_ready(uint8_t value)227*5113495bSYour Name static inline void cds_set_target_ready(uint8_t value)
228*5113495bSYour Name {
229*5113495bSYour Name 	if (value)
230*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_FW_READY);
231*5113495bSYour Name 	else
232*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_FW_READY);
233*5113495bSYour Name }
234*5113495bSYour Name 
235*5113495bSYour Name /**
236*5113495bSYour Name  * cds_set_load_in_progress() - Set load in progress
237*5113495bSYour Name  * @value: value to set
238*5113495bSYour Name  *
239*5113495bSYour Name  * Return: none
240*5113495bSYour Name  */
cds_set_load_in_progress(uint8_t value)241*5113495bSYour Name static inline void cds_set_load_in_progress(uint8_t value)
242*5113495bSYour Name {
243*5113495bSYour Name 	if (value)
244*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_LOADING);
245*5113495bSYour Name 	else
246*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_LOADING);
247*5113495bSYour Name }
248*5113495bSYour Name 
249*5113495bSYour Name /**
250*5113495bSYour Name  * cds_set_driver_loaded() - Set load completed
251*5113495bSYour Name  * @value: value to set
252*5113495bSYour Name  *
253*5113495bSYour Name  * Return: none
254*5113495bSYour Name  */
cds_set_driver_loaded(uint8_t value)255*5113495bSYour Name static inline void cds_set_driver_loaded(uint8_t value)
256*5113495bSYour Name {
257*5113495bSYour Name 	if (value)
258*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_LOADED);
259*5113495bSYour Name 	else
260*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_LOADED);
261*5113495bSYour Name }
262*5113495bSYour Name 
263*5113495bSYour Name /**
264*5113495bSYour Name  * cds_set_unload_in_progress() - Set unload in progress
265*5113495bSYour Name  * @value: value to set
266*5113495bSYour Name  *
267*5113495bSYour Name  * Return: none
268*5113495bSYour Name  */
cds_set_unload_in_progress(uint8_t value)269*5113495bSYour Name static inline void cds_set_unload_in_progress(uint8_t value)
270*5113495bSYour Name {
271*5113495bSYour Name 	if (value)
272*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_UNLOADING);
273*5113495bSYour Name 	else
274*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_UNLOADING);
275*5113495bSYour Name }
276*5113495bSYour Name 
277*5113495bSYour Name /**
278*5113495bSYour Name  * cds_set_driver_state_module_stop() - Setting module stop in progress or done
279*5113495bSYour Name  *
280*5113495bSYour Name  * @value: value to set
281*5113495bSYour Name  *
282*5113495bSYour Name  * Return: none
283*5113495bSYour Name  */
cds_set_driver_state_module_stop(bool value)284*5113495bSYour Name static inline void cds_set_driver_state_module_stop(bool value)
285*5113495bSYour Name {
286*5113495bSYour Name 	if (value)
287*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_MODULE_STOP);
288*5113495bSYour Name 	else
289*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_MODULE_STOP);
290*5113495bSYour Name }
291*5113495bSYour Name 
292*5113495bSYour Name /**
293*5113495bSYour Name  * cds_is_driver_loaded() - Is driver loaded
294*5113495bSYour Name  *
295*5113495bSYour Name  * Return: true if driver is loaded or false otherwise.
296*5113495bSYour Name  */
cds_is_driver_loaded(void)297*5113495bSYour Name static inline bool cds_is_driver_loaded(void)
298*5113495bSYour Name {
299*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
300*5113495bSYour Name 
301*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_LOADED);
302*5113495bSYour Name }
303*5113495bSYour Name 
304*5113495bSYour Name /**
305*5113495bSYour Name  * cds_set_assert_target_in_progress() - Setting assert target in progress
306*5113495bSYour Name  *
307*5113495bSYour Name  * @value: value to set
308*5113495bSYour Name  *
309*5113495bSYour Name  * Return: none
310*5113495bSYour Name  */
cds_set_assert_target_in_progress(bool value)311*5113495bSYour Name static inline void cds_set_assert_target_in_progress(bool value)
312*5113495bSYour Name {
313*5113495bSYour Name 	if (value)
314*5113495bSYour Name 		cds_set_driver_state(CDS_DRIVER_STATE_ASSERTING_TARGET);
315*5113495bSYour Name 	else
316*5113495bSYour Name 		cds_clear_driver_state(CDS_DRIVER_STATE_ASSERTING_TARGET);
317*5113495bSYour Name }
318*5113495bSYour Name 
319*5113495bSYour Name /**
320*5113495bSYour Name  * cds_is_target_asserting() - Is driver asserting target
321*5113495bSYour Name  *
322*5113495bSYour Name  * Return: true if driver is asserting target
323*5113495bSYour Name  */
cds_is_target_asserting(void)324*5113495bSYour Name static inline bool cds_is_target_asserting(void)
325*5113495bSYour Name {
326*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
327*5113495bSYour Name 
328*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_ASSERTING_TARGET);
329*5113495bSYour Name }
330*5113495bSYour Name 
331*5113495bSYour Name /**
332*5113495bSYour Name  * cds_set_sys_rebooting() - Set system reboot in progress
333*5113495bSYour Name  *
334*5113495bSYour Name  * Return: none
335*5113495bSYour Name  */
336*5113495bSYour Name void cds_set_sys_rebooting(void);
337*5113495bSYour Name 
338*5113495bSYour Name /**
339*5113495bSYour Name  * cds_sys_reboot_protect() - Require the lock for system reboot and get
340*5113495bSYour Name  * system rebooting state
341*5113495bSYour Name  *
342*5113495bSYour Name  * cds_sys_reboot_protect() and cds_sys_reboot_unprotect() MUST be used
343*5113495bSYour Name  * in pair.
344*5113495bSYour Name  *
345*5113495bSYour Name  * Return: true if system is rebooting, false otherwise
346*5113495bSYour Name  */
347*5113495bSYour Name bool cds_sys_reboot_protect(void);
348*5113495bSYour Name 
349*5113495bSYour Name /**
350*5113495bSYour Name  * cds_sys_reboot_unprotect() - Release the lock for system reboot
351*5113495bSYour Name  *
352*5113495bSYour Name  * Return: none
353*5113495bSYour Name  */
354*5113495bSYour Name void cds_sys_reboot_unprotect(void);
355*5113495bSYour Name 
356*5113495bSYour Name /**
357*5113495bSYour Name  * cds_init() - Initialize CDS
358*5113495bSYour Name  *
359*5113495bSYour Name  * This function allocates the resource required for CDS, but does not
360*5113495bSYour Name  * initialize all the members. This overall initialization will happen at
361*5113495bSYour Name  * cds_open().
362*5113495bSYour Name  *
363*5113495bSYour Name  * Return: QDF_STATUS_SUCCESS if CDS was initialized and an error on failure
364*5113495bSYour Name  */
365*5113495bSYour Name QDF_STATUS cds_init(void);
366*5113495bSYour Name 
367*5113495bSYour Name void cds_deinit(void);
368*5113495bSYour Name 
369*5113495bSYour Name QDF_STATUS cds_pre_enable(void);
370*5113495bSYour Name 
371*5113495bSYour Name QDF_STATUS cds_open(struct wlan_objmgr_psoc *psoc);
372*5113495bSYour Name 
373*5113495bSYour Name /**
374*5113495bSYour Name  * cds_dp_open() - Open datapath module
375*5113495bSYour Name  * @psoc: object manager soc handle
376*5113495bSYour Name  *
377*5113495bSYour Name  * API to map the datapath rings to interrupts
378*5113495bSYour Name  * and also open the datapath pdev module.
379*5113495bSYour Name  *
380*5113495bSYour Name  * Return: QDF status
381*5113495bSYour Name  */
382*5113495bSYour Name QDF_STATUS cds_dp_open(struct wlan_objmgr_psoc *psoc);
383*5113495bSYour Name 
384*5113495bSYour Name /**
385*5113495bSYour Name  * cds_enable() - start/enable cds module
386*5113495bSYour Name  * @psoc: Psoc pointer
387*5113495bSYour Name  *
388*5113495bSYour Name  * Return: QDF status
389*5113495bSYour Name  */
390*5113495bSYour Name QDF_STATUS cds_enable(struct wlan_objmgr_psoc *psoc);
391*5113495bSYour Name 
392*5113495bSYour Name QDF_STATUS cds_disable(struct wlan_objmgr_psoc *psoc);
393*5113495bSYour Name 
394*5113495bSYour Name QDF_STATUS cds_post_disable(void);
395*5113495bSYour Name 
396*5113495bSYour Name QDF_STATUS cds_close(struct wlan_objmgr_psoc *psoc);
397*5113495bSYour Name 
398*5113495bSYour Name /**
399*5113495bSYour Name  * cds_dp_close() - Close datapath module
400*5113495bSYour Name  * @psoc: Object manager soc handle
401*5113495bSYour Name  *
402*5113495bSYour Name  * API used to detach interrupts assigned to service
403*5113495bSYour Name  * datapath rings and close pdev module
404*5113495bSYour Name  *
405*5113495bSYour Name  * Return: Status
406*5113495bSYour Name  */
407*5113495bSYour Name QDF_STATUS cds_dp_close(struct wlan_objmgr_psoc *psoc);
408*5113495bSYour Name 
409*5113495bSYour Name /**
410*5113495bSYour Name  * cds_get_context() - get context data area
411*5113495bSYour Name  * @module_id: ID of the module who's context data is being retrieved.
412*5113495bSYour Name  *
413*5113495bSYour Name  * Each module in the system has a context/data area that is allocated
414*5113495bSYour Name  * and managed by CDS.  This API allows any user to get a pointer to its
415*5113495bSYour Name  * allocated context data area from the CDS global context.
416*5113495bSYour Name  *
417*5113495bSYour Name  * Return: pointer to the context data area of the module ID
418*5113495bSYour Name  *	   specified, or NULL if the context data is not allocated for
419*5113495bSYour Name  *	   the module ID specified.
420*5113495bSYour Name  */
421*5113495bSYour Name #define cds_get_context(module_id) \
422*5113495bSYour Name 	__cds_get_context(module_id, __func__)
423*5113495bSYour Name void *__cds_get_context(QDF_MODULE_ID module_id, const char *func);
424*5113495bSYour Name 
425*5113495bSYour Name void *cds_get_global_context(void);
426*5113495bSYour Name 
427*5113495bSYour Name QDF_STATUS cds_alloc_context(QDF_MODULE_ID module_id, void **module_context,
428*5113495bSYour Name 			     uint32_t size);
429*5113495bSYour Name 
430*5113495bSYour Name QDF_STATUS cds_free_context(QDF_MODULE_ID module_id, void *module_context);
431*5113495bSYour Name 
432*5113495bSYour Name QDF_STATUS cds_set_context(QDF_MODULE_ID module_id, void *context);
433*5113495bSYour Name 
434*5113495bSYour Name void cds_flush_work(void *work);
435*5113495bSYour Name void cds_flush_delayed_work(void *dwork);
436*5113495bSYour Name 
437*5113495bSYour Name #ifdef REMOVE_PKT_LOG
438*5113495bSYour Name static inline
cds_is_packet_log_enabled(void)439*5113495bSYour Name bool cds_is_packet_log_enabled(void)
440*5113495bSYour Name {
441*5113495bSYour Name 	return false;
442*5113495bSYour Name }
443*5113495bSYour Name #else
444*5113495bSYour Name bool cds_is_packet_log_enabled(void);
445*5113495bSYour Name #endif
446*5113495bSYour Name 
447*5113495bSYour Name /**
448*5113495bSYour Name  * cds_get_recovery_reason() - get self recovery reason
449*5113495bSYour Name  * @reason: cds hang reason
450*5113495bSYour Name  *
451*5113495bSYour Name  * Return: None
452*5113495bSYour Name  */
453*5113495bSYour Name void cds_get_recovery_reason(enum qdf_hang_reason *reason);
454*5113495bSYour Name 
455*5113495bSYour Name /**
456*5113495bSYour Name  * cds_reset_recovery_reason() - reset the reason to unspecified
457*5113495bSYour Name  *
458*5113495bSYour Name  * Return: None
459*5113495bSYour Name  */
460*5113495bSYour Name void cds_reset_recovery_reason(void);
461*5113495bSYour Name 
462*5113495bSYour Name /**
463*5113495bSYour Name  * cds_trigger_recovery() - trigger self recovery
464*5113495bSYour Name  * @reason: recovery reason
465*5113495bSYour Name  *
466*5113495bSYour Name  * Return: none
467*5113495bSYour Name  */
468*5113495bSYour Name #define cds_trigger_recovery(reason) \
469*5113495bSYour Name 	__cds_trigger_recovery(reason, __func__, __LINE__)
470*5113495bSYour Name 
471*5113495bSYour Name void cds_trigger_recovery_psoc(void *psoc, enum qdf_hang_reason reason,
472*5113495bSYour Name 			       const char *func, const uint32_t line);
473*5113495bSYour Name 
474*5113495bSYour Name void __cds_trigger_recovery(enum qdf_hang_reason reason, const char *func,
475*5113495bSYour Name 			    const uint32_t line);
476*5113495bSYour Name 
477*5113495bSYour Name void cds_set_wakelock_logging(bool value);
478*5113495bSYour Name bool cds_is_wakelock_enabled(void);
479*5113495bSYour Name void cds_set_ring_log_level(uint32_t ring_id, uint32_t log_level);
480*5113495bSYour Name enum wifi_driver_log_level cds_get_ring_log_level(uint32_t ring_id);
481*5113495bSYour Name void cds_set_multicast_logging(uint8_t value);
482*5113495bSYour Name uint8_t cds_is_multicast_logging(void);
483*5113495bSYour Name QDF_STATUS cds_set_log_completion(uint32_t is_fatal,
484*5113495bSYour Name 		uint32_t type,
485*5113495bSYour Name 		uint32_t sub_type,
486*5113495bSYour Name 		bool recovery_needed);
487*5113495bSYour Name void cds_get_and_reset_log_completion(uint32_t *is_fatal,
488*5113495bSYour Name 		uint32_t *type,
489*5113495bSYour Name 		uint32_t *sub_type,
490*5113495bSYour Name 		bool *recovery_needed);
491*5113495bSYour Name bool cds_is_log_report_in_progress(void);
492*5113495bSYour Name bool cds_is_fatal_event_enabled(void);
493*5113495bSYour Name 
494*5113495bSYour Name #ifdef WLAN_FEATURE_TSF_PLUS_SOCK_TS
495*5113495bSYour Name bool cds_is_ptp_rx_opt_enabled(void);
496*5113495bSYour Name bool cds_is_ptp_tx_opt_enabled(void);
497*5113495bSYour Name #else
cds_is_ptp_rx_opt_enabled(void)498*5113495bSYour Name static inline bool cds_is_ptp_rx_opt_enabled(void)
499*5113495bSYour Name {
500*5113495bSYour Name 	return false;
501*5113495bSYour Name }
502*5113495bSYour Name 
cds_is_ptp_tx_opt_enabled(void)503*5113495bSYour Name static inline bool cds_is_ptp_tx_opt_enabled(void)
504*5113495bSYour Name {
505*5113495bSYour Name 	return false;
506*5113495bSYour Name }
507*5113495bSYour Name #endif
508*5113495bSYour Name 
509*5113495bSYour Name uint32_t cds_get_log_indicator(void);
510*5113495bSYour Name void cds_set_fatal_event(bool value);
511*5113495bSYour Name void cds_wlan_flush_host_logs_for_fatal(void);
512*5113495bSYour Name 
513*5113495bSYour Name void cds_init_log_completion(void);
514*5113495bSYour Name QDF_STATUS cds_flush_logs(uint32_t is_fatal,
515*5113495bSYour Name 		uint32_t indicator,
516*5113495bSYour Name 		uint32_t reason_code,
517*5113495bSYour Name 		bool dump_mac_trace,
518*5113495bSYour Name 		bool recovery_needed);
519*5113495bSYour Name void cds_logging_set_fw_flush_complete(void);
520*5113495bSYour Name void cds_svc_fw_shutdown_ind(struct device *dev);
521*5113495bSYour Name #ifdef FEATURE_WLAN_DIAG_SUPPORT
522*5113495bSYour Name void cds_tdls_tx_rx_mgmt_event(uint8_t event_id, uint8_t tx_rx,
523*5113495bSYour Name 			uint8_t type, uint8_t sub_type, uint8_t *peer_mac);
524*5113495bSYour Name #else
525*5113495bSYour Name static inline
cds_tdls_tx_rx_mgmt_event(uint8_t event_id,uint8_t tx_rx,uint8_t type,uint8_t sub_type,uint8_t * peer_mac)526*5113495bSYour Name void cds_tdls_tx_rx_mgmt_event(uint8_t event_id, uint8_t tx_rx,
527*5113495bSYour Name 			uint8_t type, uint8_t sub_type, uint8_t *peer_mac)
528*5113495bSYour Name 
529*5113495bSYour Name {
530*5113495bSYour Name }
531*5113495bSYour Name #endif /* FEATURE_WLAN_DIAG_SUPPORT */
532*5113495bSYour Name 
533*5113495bSYour Name int cds_get_radio_index(void);
534*5113495bSYour Name QDF_STATUS cds_set_radio_index(int radio_index);
535*5113495bSYour Name void cds_init_ini_config(struct cds_config_info *cds_cfg);
536*5113495bSYour Name void cds_deinit_ini_config(void);
537*5113495bSYour Name struct cds_config_info *cds_get_ini_config(void);
538*5113495bSYour Name 
539*5113495bSYour Name bool cds_is_5_mhz_enabled(void);
540*5113495bSYour Name bool cds_is_10_mhz_enabled(void);
541*5113495bSYour Name bool cds_is_sub_20_mhz_enabled(void);
542*5113495bSYour Name bool cds_is_self_recovery_enabled(void);
543*5113495bSYour Name bool cds_is_fw_down(void);
544*5113495bSYour Name enum QDF_GLOBAL_MODE cds_get_conparam(void);
545*5113495bSYour Name 
546*5113495bSYour Name #ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
547*5113495bSYour Name void cds_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data);
548*5113495bSYour Name #else
549*5113495bSYour Name static inline
cds_pkt_stats_to_logger_thread(void * pl_hdr,void * pkt_dump,void * data)550*5113495bSYour Name void cds_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data)
551*5113495bSYour Name {
552*5113495bSYour Name }
553*5113495bSYour Name #endif
554*5113495bSYour Name 
555*5113495bSYour Name #ifdef FEATURE_HTC_CREDIT_HISTORY
556*5113495bSYour Name /**
557*5113495bSYour Name  * cds_print_htc_credit_history() - Helper function to copy HTC credit
558*5113495bSYour Name  *				    history via htc_print_credit_history()
559*5113495bSYour Name  *
560*5113495bSYour Name  * @count:	Number of lines to be copied
561*5113495bSYour Name  * @print:	Print callback to print in the buffer
562*5113495bSYour Name  * @print_priv:	Print callback private data
563*5113495bSYour Name  *
564*5113495bSYour Name  * Return:	none
565*5113495bSYour Name  */
566*5113495bSYour Name void cds_print_htc_credit_history(uint32_t count,
567*5113495bSYour Name 				qdf_abstract_print * print,
568*5113495bSYour Name 				void *print_priv);
569*5113495bSYour Name #else
570*5113495bSYour Name 
571*5113495bSYour Name static inline
cds_print_htc_credit_history(uint32_t count,qdf_abstract_print * print,void * print_priv)572*5113495bSYour Name void cds_print_htc_credit_history(uint32_t count,
573*5113495bSYour Name 				qdf_abstract_print *print,
574*5113495bSYour Name 				void *print_priv)
575*5113495bSYour Name {
576*5113495bSYour Name }
577*5113495bSYour Name #endif
578*5113495bSYour Name /**
579*5113495bSYour Name  * cds_is_group_addr() - checks whether addr is multi cast
580*5113495bSYour Name  * @mac_addr: address to be checked for multicast
581*5113495bSYour Name  *
582*5113495bSYour Name  * Check if the input mac addr is multicast addr
583*5113495bSYour Name  *
584*5113495bSYour Name  * Return: true if multicast addr else false
585*5113495bSYour Name  */
586*5113495bSYour Name static inline
cds_is_group_addr(uint8_t * mac_addr)587*5113495bSYour Name bool cds_is_group_addr(uint8_t *mac_addr)
588*5113495bSYour Name {
589*5113495bSYour Name 	if (mac_addr[0] & 0x01)
590*5113495bSYour Name 		return true;
591*5113495bSYour Name 	else
592*5113495bSYour Name 		return false;
593*5113495bSYour Name }
594*5113495bSYour Name 
595*5113495bSYour Name #ifdef FEATURE_ALIGN_STATS_FROM_DP
596*5113495bSYour Name /**
597*5113495bSYour Name  * cds_dp_get_vdev_stats() - get vdev stats from DP
598*5113495bSYour Name  * @vdev_id: vdev id
599*5113495bSYour Name  * @stats: structure of counters which CP is interested in
600*5113495bSYour Name  *
601*5113495bSYour Name  * Return: if get vdev stats from DP success, return true otherwise false
602*5113495bSYour Name  */
603*5113495bSYour Name bool cds_dp_get_vdev_stats(uint8_t vdev_id, struct cds_vdev_dp_stats *stats);
604*5113495bSYour Name #else
605*5113495bSYour Name static inline bool
cds_dp_get_vdev_stats(uint8_t vdev_id,struct cds_vdev_dp_stats * stats)606*5113495bSYour Name cds_dp_get_vdev_stats(uint8_t vdev_id, struct cds_vdev_dp_stats *stats)
607*5113495bSYour Name {
608*5113495bSYour Name 	return false;
609*5113495bSYour Name }
610*5113495bSYour Name #endif
611*5113495bSYour Name 
612*5113495bSYour Name /**
613*5113495bSYour Name  * cds_smmu_mem_map_setup() - Check SMMU S1 stage enable
614*5113495bSYour Name  *                            status and setup wlan driver
615*5113495bSYour Name  * @osdev: Parent device instance
616*5113495bSYour Name  * @ipa_present: IPA HW support flag
617*5113495bSYour Name  *
618*5113495bSYour Name  * This API checks if SMMU S1 translation is enabled in
619*5113495bSYour Name  * platform driver or not and sets it accordingly in driver.
620*5113495bSYour Name  *
621*5113495bSYour Name  * Return: QDF_STATUS
622*5113495bSYour Name  */
623*5113495bSYour Name QDF_STATUS cds_smmu_mem_map_setup(qdf_device_t osdev, bool ipa_present);
624*5113495bSYour Name 
625*5113495bSYour Name /**
626*5113495bSYour Name  * cds_smmu_map_unmap() - Map / Unmap DMA buffer to IPA UC
627*5113495bSYour Name  * @map: Map / unmap operation
628*5113495bSYour Name  * @num_buf: Number of buffers in array
629*5113495bSYour Name  * @buf_arr: Buffer array of DMA mem mapping info
630*5113495bSYour Name  *
631*5113495bSYour Name  * This API maps/unmaps WLAN-IPA buffers if SMMU S1 translation
632*5113495bSYour Name  * is enabled.
633*5113495bSYour Name  *
634*5113495bSYour Name  * Return: Status of map operation
635*5113495bSYour Name  */
636*5113495bSYour Name int cds_smmu_map_unmap(bool map, uint32_t num_buf, qdf_mem_info_t *buf_arr);
637*5113495bSYour Name 
638*5113495bSYour Name /**
639*5113495bSYour Name  * cds_is_driver_transitioning() - Is driver transitioning
640*5113495bSYour Name  *
641*5113495bSYour Name  * Return: true if driver is loading/unloading/recovering and false otherwise.
642*5113495bSYour Name  */
cds_is_driver_transitioning(void)643*5113495bSYour Name static inline bool cds_is_driver_transitioning(void)
644*5113495bSYour Name {
645*5113495bSYour Name 	enum cds_driver_state state = cds_get_driver_state();
646*5113495bSYour Name 
647*5113495bSYour Name 	return __CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_LOADING) ||
648*5113495bSYour Name 		__CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_UNLOADING) ||
649*5113495bSYour Name 		__CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_RECOVERING) ||
650*5113495bSYour Name 		__CDS_IS_DRIVER_STATE(state, CDS_DRIVER_STATE_BAD);
651*5113495bSYour Name }
652*5113495bSYour Name 
653*5113495bSYour Name #endif /* if !defined __CDS_API_H */
654