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