cfg_nan_api.h 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /*
  2. * Copyright (c) 2018-2020 The Linux Foundation. All rights reserved.
  3. * Copyright (c) 2022-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. #if !defined(__NAN_CFG_API_H__)
  20. #define __NAN_CFG_API_H__
  21. /**
  22. * DOC: nan_cfg_api.h
  23. *
  24. * NAN feature INI configuration parameters get/set APIs
  25. */
  26. #include "qdf_types.h"
  27. struct wlan_objmgr_psoc;
  28. #ifdef WLAN_FEATURE_NAN
  29. /**
  30. * cfg_nan_get_enable() - get NAN support enable status
  31. * @psoc: pointer to psoc object
  32. *
  33. * This function returns NAN enable status
  34. */
  35. bool cfg_nan_get_enable(struct wlan_objmgr_psoc *psoc);
  36. /**
  37. * cfg_nan_get_datapath_enable() - get NAN Datapath support enable status
  38. * @psoc: pointer to psoc object
  39. *
  40. * This function returns NAN Datapath enable status
  41. */
  42. bool cfg_nan_get_datapath_enable(struct wlan_objmgr_psoc *psoc);
  43. /**
  44. * cfg_nan_get_ndi_mac_randomize() - get NDI MAC randomize enable status
  45. * @psoc: pointer to psoc object
  46. *
  47. * This function returns NAN Datapath Interface MAC randomization status
  48. */
  49. bool cfg_nan_get_ndi_mac_randomize(struct wlan_objmgr_psoc *psoc);
  50. /**
  51. * cfg_nan_get_ndp_inactivity_timeout() - get NDP inactivity timeout value
  52. * @psoc: pointer to psoc object
  53. * @val: pointer to the value where inactivity timeout has to be copied to
  54. *
  55. * Return: QDF_STATUS
  56. */
  57. QDF_STATUS cfg_nan_get_ndp_inactivity_timeout(struct wlan_objmgr_psoc *psoc,
  58. uint16_t *val);
  59. /**
  60. * cfg_nan_get_ndp_keepalive_period() - get NDP keepalive period
  61. * @psoc: pointer to psoc object
  62. * @val: pointer to the value where keepalive period has to be copied to
  63. *
  64. * Return: QDF_STATUS
  65. */
  66. QDF_STATUS cfg_nan_get_ndp_keepalive_period(struct wlan_objmgr_psoc *psoc,
  67. uint16_t *val);
  68. /**
  69. * cfg_nan_get_ndp_max_sessions() - get NDP max sessions host supports
  70. * @psoc: pointer to psoc object
  71. * @val: pointer to hold max ndp sessions
  72. *
  73. * Return: QDF_STATUS
  74. */
  75. QDF_STATUS cfg_nan_get_ndp_max_sessions(struct wlan_objmgr_psoc *psoc,
  76. uint32_t *val);
  77. /**
  78. * cfg_nan_get_max_ndi() - get max number of ndi host supports
  79. * @psoc: pointer to psoc object
  80. * @val: pointer to hold max number of ndi
  81. *
  82. * Return: QDF_STATUS
  83. */
  84. QDF_STATUS cfg_nan_get_max_ndi(struct wlan_objmgr_psoc *psoc, uint32_t *val);
  85. /**
  86. * cfg_nan_get_support_mp0_discovery() - get value of config support mp0
  87. * discovery
  88. * @psoc: pointer to psoc object
  89. *
  90. * Return: Value of config join clustur with mp
  91. */
  92. bool cfg_nan_get_support_mp0_discovery(struct wlan_objmgr_psoc *psoc);
  93. /**
  94. * cfg_nan_is_roam_config_disabled() - get value of nan config roam disable
  95. * discovery
  96. * @psoc: pointer to psoc object
  97. *
  98. * Return: true on sta roam disable by nan else false
  99. */
  100. bool cfg_nan_is_roam_config_disabled(struct wlan_objmgr_psoc *psoc);
  101. /**
  102. * cfg_nan_is_eht_cap_enable() - Get NAN EHT capability
  103. * @psoc: pointer to psoc object
  104. *
  105. * Return: Boolean flag indicating whether the NAN EHT capability is
  106. * disabled or not
  107. */
  108. bool cfg_nan_is_eht_cap_enable(struct wlan_objmgr_psoc *psoc);
  109. #else
  110. static inline
  111. bool cfg_nan_is_roam_config_disabled(struct wlan_objmgr_psoc *psoc)
  112. {
  113. return false;
  114. }
  115. static inline bool cfg_nan_get_enable(struct wlan_objmgr_psoc *psoc)
  116. {
  117. return false;
  118. }
  119. static inline bool cfg_nan_get_datapath_enable(struct wlan_objmgr_psoc *psoc)
  120. {
  121. return false;
  122. }
  123. static inline bool cfg_nan_get_ndi_mac_randomize(struct wlan_objmgr_psoc *psoc)
  124. {
  125. return false;
  126. }
  127. static inline
  128. QDF_STATUS cfg_nan_get_ndp_inactivity_timeout(struct wlan_objmgr_psoc *psoc,
  129. uint16_t *val)
  130. {
  131. return QDF_STATUS_SUCCESS;
  132. }
  133. static inline
  134. QDF_STATUS cfg_nan_get_ndp_keepalive_period(struct wlan_objmgr_psoc *psoc,
  135. uint16_t *val)
  136. {
  137. return QDF_STATUS_SUCCESS;
  138. }
  139. static inline
  140. QDF_STATUS cfg_nan_get_ndp_max_sessions(struct wlan_objmgr_psoc *psoc,
  141. uint32_t *val)
  142. {
  143. return QDF_STATUS_SUCCESS;
  144. }
  145. static inline
  146. QDF_STATUS cfg_nan_get_max_ndi(struct wlan_objmgr_psoc *psoc, uint32_t *val)
  147. {
  148. return QDF_STATUS_SUCCESS;
  149. }
  150. static inline bool cfg_nan_get_support_mp0_discovery(
  151. struct wlan_objmgr_psoc *psoc)
  152. {
  153. return false;
  154. }
  155. static inline bool cfg_nan_is_eht_cap_enable(struct wlan_objmgr_psoc *psoc)
  156. {
  157. return false;
  158. }
  159. #endif
  160. #endif