wlan_utility.h 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. /*
  2. * Copyright (c) 2017-2018 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. /**
  19. * DOC: Contains mandatory API from legacy
  20. */
  21. #ifndef _WLAN_UTILITY_H_
  22. #define _WLAN_UTILITY_H_
  23. #include <qdf_types.h>
  24. #include <wlan_objmgr_psoc_obj.h>
  25. #include <wlan_objmgr_pdev_obj.h>
  26. #include <wlan_objmgr_vdev_obj.h>
  27. /**
  28. * struct wlan_find_vdev_filter - find vdev filter object. this can be extended
  29. * @ifname: interface name of vdev
  30. * @found_vdev: found vdev object matching one or more of above params
  31. */
  32. struct wlan_find_vdev_filter {
  33. char *ifname;
  34. struct wlan_objmgr_vdev *found_vdev;
  35. };
  36. /**
  37. * wlan_chan_to_freq() - converts channel to frequency
  38. * @chan: channel number
  39. *
  40. * @return frequency of the channel
  41. */
  42. uint32_t wlan_chan_to_freq(uint8_t chan);
  43. /*
  44. * wlan_is_dsrc_channel() - is the channel DSRC
  45. * @center_freq: center freq of the channel
  46. *
  47. * Return: true if DSRC channel or false otherwise
  48. */
  49. bool wlan_is_dsrc_channel(uint16_t center_freq);
  50. /**
  51. * wlan_freq_to_chan() - converts frequency to channel
  52. * @freq: frequency
  53. *
  54. * Return: channel of frequency
  55. */
  56. uint8_t wlan_freq_to_chan(uint32_t freq);
  57. /**
  58. * wlan_is_ie_valid() - Determine if an IE sequence is valid
  59. * @ie: Pointer to the IE buffer
  60. * @ie_len: Length of the IE buffer @ie
  61. *
  62. * This function validates that the IE sequence is valid by verifying
  63. * that the sum of the lengths of the embedded elements match the
  64. * length of the sequence.
  65. *
  66. * Note well that a 0-length IE sequence is considered valid.
  67. *
  68. * Return: true if the IE sequence is valid, false if it is invalid
  69. */
  70. bool wlan_is_ie_valid(const uint8_t *ie, size_t ie_len);
  71. /**
  72. * wlan_get_ie_ptr_from_eid() - Find out ie from eid
  73. * @eid: element id
  74. * @ie: source ie address
  75. * @ie_len: source ie length
  76. *
  77. * Return: vendor ie address - success
  78. * NULL - failure
  79. */
  80. const uint8_t *wlan_get_ie_ptr_from_eid(uint8_t eid,
  81. const uint8_t *ie,
  82. int ie_len);
  83. /**
  84. * wlan_get_vendor_ie_ptr_from_oui() - Find out vendor ie
  85. * @oui: oui buffer
  86. * @oui_size: oui size
  87. * @ie: source ie address
  88. * @ie_len: source ie length
  89. *
  90. * This function find out vendor ie by pass source ie and vendor oui.
  91. *
  92. * Return: vendor ie address - success
  93. * NULL - failure
  94. */
  95. const uint8_t *wlan_get_vendor_ie_ptr_from_oui(const uint8_t *oui,
  96. uint8_t oui_size,
  97. const uint8_t *ie,
  98. uint16_t ie_len);
  99. /**
  100. * wlan_get_ext_ie_ptr_from_ext_id() - Find out ext ie
  101. * @oui: oui buffer
  102. * @oui_size: oui size
  103. * @ie: source ie address
  104. * @ie_len: source ie length
  105. *
  106. * This function find out ext ie from ext id (passed oui)
  107. *
  108. * Return: vendor ie address - success
  109. * NULL - failure
  110. */
  111. const uint8_t *wlan_get_ext_ie_ptr_from_ext_id(const uint8_t *oui,
  112. uint8_t oui_size,
  113. const uint8_t *ie,
  114. uint16_t ie_len);
  115. /**
  116. * wlan_is_emulation_platform() - check if platform is emulation based
  117. * @phy_version - psoc nif phy_version
  118. *
  119. * Return: boolean value based on platform type
  120. */
  121. bool wlan_is_emulation_platform(uint32_t phy_version);
  122. /**
  123. * wlan_get_pdev_id_from_vdev_id() - Helper func to derive pdev id from vdev_id
  124. * @psoc : psoc object
  125. * @vdev_id : vdev identifier
  126. * @dbg_id : object manager debug id
  127. *
  128. * This function is used to derive the pdev id from vdev id for a psoc
  129. *
  130. * Return : pdev_id - +ve integer for success and WLAN_INVALID_PDEV_ID
  131. * for failure
  132. */
  133. uint32_t wlan_get_pdev_id_from_vdev_id(struct wlan_objmgr_psoc *psoc,
  134. uint8_t vdev_id,
  135. wlan_objmgr_ref_dbgid dbg_id);
  136. /**
  137. * wlan_util_get_vdev_by_ifname() - function to return vdev object from psoc
  138. * matching given interface name
  139. * @psoc : psoc object
  140. * @ifname : interface name
  141. * @ref_id : object manager ref id
  142. *
  143. * This function returns vdev object from psoc by interface name. If found this
  144. * will also take reference with given ref_id
  145. *
  146. * Return : vdev object if found, NULL otherwise
  147. */
  148. struct wlan_objmgr_vdev *wlan_util_get_vdev_by_ifname(
  149. struct wlan_objmgr_psoc *psoc, char *ifname,
  150. wlan_objmgr_ref_dbgid ref_id);
  151. /**
  152. * wlan_util_vdev_get_if_name() - get vdev's interface name
  153. * @vdev: VDEV object
  154. *
  155. * API to get vdev's interface name
  156. *
  157. * Return:
  158. * @id: vdev's interface name
  159. */
  160. uint8_t *wlan_util_vdev_get_if_name(struct wlan_objmgr_vdev *vdev);
  161. /*
  162. * wlan_util_is_vap_active() - Check for vap active
  163. * @pdev: pdev pointer
  164. * @dbg_id: debug id for ref counting
  165. *
  166. * @Return: QDF_STATUS_SUCCESS in case of vap active
  167. */
  168. QDF_STATUS wlan_util_is_vap_active(struct wlan_objmgr_pdev *pdev,
  169. wlan_objmgr_ref_dbgid dbg_id);
  170. #endif /* _WLAN_UTILITY_H_ */