wlan_cfg80211.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. /*
  2. * Copyright (c) 2016-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: declares driver functions interfacing with linux kernel
  20. */
  21. #ifndef _WLAN_CFG80211_H_
  22. #define _WLAN_CFG80211_H_
  23. #include <linux/version.h>
  24. #include <linux/netdevice.h>
  25. #include <net/netlink.h>
  26. #include <net/cfg80211.h>
  27. #include <qca_vendor.h>
  28. #define cfg80211_alert(params...) \
  29. QDF_TRACE_FATAL(QDF_MODULE_ID_OS_IF, params)
  30. #define cfg80211_err(params...) \
  31. QDF_TRACE_ERROR(QDF_MODULE_ID_OS_IF, params)
  32. #define cfg80211_warn(params...) \
  33. QDF_TRACE_WARN(QDF_MODULE_ID_OS_IF, params)
  34. #define cfg80211_notice(params...) \
  35. QDF_TRACE_INFO(QDF_MODULE_ID_OS_IF, params)
  36. #define cfg80211_info(params...) \
  37. QDF_TRACE_INFO(QDF_MODULE_ID_OS_IF, params)
  38. #define cfg80211_debug(params...) \
  39. QDF_TRACE_DEBUG(QDF_MODULE_ID_OS_IF, params)
  40. #define COMMON_VENDOR_COMMANDS \
  41. { \
  42. .info.vendor_id = OUI_QCA, \
  43. .info.subcmd = QCA_NL80211_VENDOR_SUBCMD_SET_WIFI_CONFIGURATION,\
  44. .flags = WIPHY_VENDOR_CMD_NEED_WDEV | \
  45. WIPHY_VENDOR_CMD_NEED_NETDEV, \
  46. .doit = NULL \
  47. }, \
  48. { \
  49. .info.vendor_id = OUI_QCA, \
  50. .info.subcmd = QCA_NL80211_VENDOR_SUBCMD_GET_WIFI_CONFIGURATION,\
  51. .flags = WIPHY_VENDOR_CMD_NEED_WDEV | \
  52. WIPHY_VENDOR_CMD_NEED_NETDEV, \
  53. .doit = NULL \
  54. },
  55. #undef nla_parse
  56. #undef nla_parse_nested
  57. #if LINUX_VERSION_CODE < KERNEL_VERSION(4, 12, 0)
  58. static inline int wlan_cfg80211_nla_parse(struct nlattr **tb,
  59. int maxtype,
  60. const struct nlattr *head,
  61. int len,
  62. const struct nla_policy *policy)
  63. {
  64. return nla_parse(tb, maxtype, head, len, policy);
  65. }
  66. static inline int
  67. wlan_cfg80211_nla_parse_nested(struct nlattr *tb[],
  68. int maxtype,
  69. const struct nlattr *nla,
  70. const struct nla_policy *policy)
  71. {
  72. return nla_parse_nested(tb, maxtype, nla, policy);
  73. }
  74. #else
  75. static inline int wlan_cfg80211_nla_parse(struct nlattr **tb,
  76. int maxtype,
  77. const struct nlattr *head,
  78. int len,
  79. const struct nla_policy *policy)
  80. {
  81. return nla_parse(tb, maxtype, head, len, policy, NULL);
  82. }
  83. static inline int
  84. wlan_cfg80211_nla_parse_nested(struct nlattr *tb[],
  85. int maxtype,
  86. const struct nlattr *nla,
  87. const struct nla_policy *policy)
  88. {
  89. return nla_parse_nested(tb, maxtype, nla, policy, NULL);
  90. }
  91. #endif
  92. #define nla_parse(...) (obsolete, use wlan_cfg80211_nla_parse)
  93. #define nla_parse_nested(...) (obsolete, use wlan_cfg80211_nla_parse_nested)
  94. #if (LINUX_VERSION_CODE < KERNEL_VERSION(4, 7, 0))
  95. static inline int
  96. wlan_cfg80211_nla_put_u64(struct sk_buff *skb, int attrtype, u64 value)
  97. {
  98. return nla_put_u64(skb, attrtype, value);
  99. }
  100. #else
  101. static inline int
  102. wlan_cfg80211_nla_put_u64(struct sk_buff *skb, int attrtype, u64 value)
  103. {
  104. return nla_put_u64_64bit(skb, attrtype, value, NL80211_ATTR_PAD);
  105. }
  106. #endif
  107. #endif