feature.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*
  2. * Copyright (c) 2014 Broadcom Corporation
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
  11. * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  13. * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
  14. * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef _BRCMF_FEATURE_H
  17. #define _BRCMF_FEATURE_H
  18. /*
  19. * Features:
  20. *
  21. * MBSS: multiple BSSID support (eg. guest network in AP mode).
  22. * MCHAN: multi-channel for concurrent P2P.
  23. * PNO: preferred network offload.
  24. * WOWL: Wake-On-WLAN.
  25. * P2P: peer-to-peer
  26. * RSDB: Real Simultaneous Dual Band
  27. * TDLS: Tunneled Direct Link Setup
  28. * SCAN_RANDOM_MAC: Random MAC during (net detect) scheduled scan.
  29. * WOWL_ND: WOWL net detect (PNO)
  30. * WOWL_GTK: (WOWL) GTK rekeying offload
  31. * WOWL_ARP_ND: ARP and Neighbor Discovery offload support during WOWL.
  32. * MFP: 802.11w Management Frame Protection.
  33. * GSCAN: enhanced scan offload feature.
  34. * FWSUP: Firmware supplicant.
  35. * MONITOR: firmware can pass monitor packets to host.
  36. * MONITOR_FMT_RADIOTAP: firmware provides monitor packets with radiotap header
  37. */
  38. #define BRCMF_FEAT_LIST \
  39. BRCMF_FEAT_DEF(MBSS) \
  40. BRCMF_FEAT_DEF(MCHAN) \
  41. BRCMF_FEAT_DEF(PNO) \
  42. BRCMF_FEAT_DEF(WOWL) \
  43. BRCMF_FEAT_DEF(P2P) \
  44. BRCMF_FEAT_DEF(RSDB) \
  45. BRCMF_FEAT_DEF(TDLS) \
  46. BRCMF_FEAT_DEF(SCAN_RANDOM_MAC) \
  47. BRCMF_FEAT_DEF(WOWL_ND) \
  48. BRCMF_FEAT_DEF(WOWL_GTK) \
  49. BRCMF_FEAT_DEF(WOWL_ARP_ND) \
  50. BRCMF_FEAT_DEF(MFP) \
  51. BRCMF_FEAT_DEF(GSCAN) \
  52. BRCMF_FEAT_DEF(FWSUP) \
  53. BRCMF_FEAT_DEF(MONITOR) \
  54. BRCMF_FEAT_DEF(MONITOR_FMT_RADIOTAP)
  55. /*
  56. * Quirks:
  57. *
  58. * AUTO_AUTH: workaround needed for automatic authentication type.
  59. * NEED_MPC: driver needs to disable MPC during scanning operation.
  60. */
  61. #define BRCMF_QUIRK_LIST \
  62. BRCMF_QUIRK_DEF(AUTO_AUTH) \
  63. BRCMF_QUIRK_DEF(NEED_MPC)
  64. #define BRCMF_FEAT_DEF(_f) \
  65. BRCMF_FEAT_ ## _f,
  66. /*
  67. * expand feature list to enumeration.
  68. */
  69. enum brcmf_feat_id {
  70. BRCMF_FEAT_LIST
  71. BRCMF_FEAT_LAST
  72. };
  73. #undef BRCMF_FEAT_DEF
  74. #define BRCMF_QUIRK_DEF(_q) \
  75. BRCMF_FEAT_QUIRK_ ## _q,
  76. /*
  77. * expand quirk list to enumeration.
  78. */
  79. enum brcmf_feat_quirk {
  80. BRCMF_QUIRK_LIST
  81. BRCMF_FEAT_QUIRK_LAST
  82. };
  83. #undef BRCMF_QUIRK_DEF
  84. /**
  85. * brcmf_feat_attach() - determine features and quirks.
  86. *
  87. * @drvr: driver instance.
  88. */
  89. void brcmf_feat_attach(struct brcmf_pub *drvr);
  90. /**
  91. * brcmf_feat_debugfs_create() - create debugfs entries.
  92. *
  93. * @drvr: driver instance.
  94. */
  95. void brcmf_feat_debugfs_create(struct brcmf_pub *drvr);
  96. /**
  97. * brcmf_feat_is_enabled() - query feature.
  98. *
  99. * @ifp: interface instance.
  100. * @id: feature id to check.
  101. *
  102. * Return: true is feature is enabled; otherwise false.
  103. */
  104. bool brcmf_feat_is_enabled(struct brcmf_if *ifp, enum brcmf_feat_id id);
  105. /**
  106. * brcmf_feat_is_quirk_enabled() - query chip quirk.
  107. *
  108. * @ifp: interface instance.
  109. * @quirk: quirk id to check.
  110. *
  111. * Return: true is quirk is enabled; otherwise false.
  112. */
  113. bool brcmf_feat_is_quirk_enabled(struct brcmf_if *ifp,
  114. enum brcmf_feat_quirk quirk);
  115. #endif /* _BRCMF_FEATURE_H */