os_if_dp.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. /*
  2. * Copyright (c) 2022 Qualcomm Innovation Center, Inc. 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: os_if_dp.h
  20. *
  21. *
  22. */
  23. #ifndef __OSIF_DP_H__
  24. #define __OSIF_DP_H__
  25. #include "wlan_dp_public_struct.h"
  26. #include <wlan_cfg80211.h>
  27. /**
  28. * osif_dp_classify_pkt() - classify packet
  29. * @skb - sk buff
  30. *
  31. * Return: None
  32. */
  33. void osif_dp_classify_pkt(struct sk_buff *skb);
  34. /**
  35. * osif_dp_mark_pkt_type() - Mark pkt type in CB
  36. * @skb - sk buff
  37. *
  38. * Return: None
  39. */
  40. void osif_dp_mark_pkt_type(struct sk_buff *skb);
  41. /* wait time for nud stats in milliseconds */
  42. #define WLAN_WAIT_TIME_NUD_STATS 800
  43. /* nud stats skb max length */
  44. #define WLAN_NUD_STATS_LEN 800
  45. /* ARP packet type for NUD debug stats */
  46. #define WLAN_NUD_STATS_ARP_PKT_TYPE 1
  47. #define MAX_USER_COMMAND_SIZE 4096
  48. #define DNS_DOMAIN_NAME_MAX_LEN 255
  49. #define ICMPV6_ADDR_LEN 16
  50. #define CONNECTIVITY_CHECK_SET_ARP \
  51. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_ARP
  52. #define CONNECTIVITY_CHECK_SET_DNS \
  53. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_DNS
  54. #define CONNECTIVITY_CHECK_SET_TCP_HANDSHAKE \
  55. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_TCP_HANDSHAKE
  56. #define CONNECTIVITY_CHECK_SET_ICMPV4 \
  57. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_ICMPV4
  58. #define CONNECTIVITY_CHECK_SET_ICMPV6 \
  59. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_ICMPV6
  60. #define CONNECTIVITY_CHECK_SET_TCP_SYN \
  61. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_TCP_SYN
  62. #define CONNECTIVITY_CHECK_SET_TCP_SYN_ACK \
  63. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_TCP_SYN_ACK
  64. #define CONNECTIVITY_CHECK_SET_TCP_ACK \
  65. QCA_WLAN_VENDOR_CONNECTIVITY_CHECK_SET_TCP_ACK
  66. /**
  67. * os_if_dp_register_txrx_callbacks() - Register TX/RX OSIF callbacks
  68. * @cb_obj: Call back object pointer for ops registration
  69. *
  70. * Return: None
  71. */
  72. void os_if_dp_register_txrx_callbacks(struct wlan_dp_psoc_callbacks *cb_obj);
  73. /**
  74. * os_if_dp_register_hdd_callbacks() - Register callback handlers
  75. * @psoc: Pointer to psoc context
  76. * @cb_obj: Callback object pointer
  77. *
  78. * Return: None
  79. */
  80. void os_if_dp_register_hdd_callbacks(struct wlan_objmgr_psoc *psoc,
  81. struct wlan_dp_psoc_callbacks *cb_obj);
  82. /**
  83. * osif_dp_nud_register_netevent_notifier() - Register netevent notifier
  84. * @psoc: Pointer to psoc context
  85. *
  86. * Return: 0 on success, error code on failure
  87. */
  88. int osif_dp_nud_register_netevent_notifier(struct wlan_objmgr_psoc *psoc);
  89. /**
  90. * osif_dp_nud_unregister_netevent_notifier() - Unregister netevent notifier
  91. * @psoc: Pointer to psoc context
  92. *
  93. * Return: None
  94. */
  95. void osif_dp_nud_unregister_netevent_notifier(struct wlan_objmgr_psoc *psoc);
  96. /**
  97. * osif_dp_get_nud_stats() - get arp stats command to firmware
  98. * @wiphy: pointer to wireless wiphy structure.
  99. * @vdev: pointer to vdev context.
  100. * @data: pointer to apfind configuration data.
  101. * @data_len: the length in byte of apfind data.
  102. *
  103. * This is called when wlan driver needs to get arp stats to
  104. * firmware.
  105. *
  106. * Return: An error code or 0 on success.
  107. */
  108. int osif_dp_get_nud_stats(struct wiphy *wiphy, struct wlan_objmgr_vdev *vdev,
  109. const void *data, int data_len);
  110. /**
  111. * osif_dp_set_nud_stats() - set arp stats command to firmware
  112. * @wiphy: pointer to wireless wiphy structure.
  113. * @vdev: pointer to wireless_dev structure.
  114. * @data: pointer to apfind configuration data.
  115. * @data_len: the length in byte of apfind data.
  116. *
  117. * This is called when wlan driver needs to send arp stats to
  118. * firmware.
  119. *
  120. * Return: An error code or 0 on success.
  121. */
  122. int osif_dp_set_nud_stats(struct wiphy *wiphy, struct wlan_objmgr_vdev *vdev,
  123. const void *data, int data_len);
  124. #endif /* __OSIF_DP_H__ */