wlan_logging_sock_svc.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. /*
  2. * Copyright (c) 2014-2021 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. * wlan_logging_sock_svc.h
  20. *
  21. ******************************************************************************/
  22. #ifndef WLAN_LOGGING_SOCK_SVC_H
  23. #define WLAN_LOGGING_SOCK_SVC_H
  24. #include <wlan_nlink_srv.h>
  25. #include <qdf_status.h>
  26. #include <qdf_trace.h>
  27. #include <wlan_nlink_common.h>
  28. int wlan_logging_sock_init_svc(void);
  29. int wlan_logging_sock_deinit_svc(void);
  30. int wlan_log_to_user(QDF_TRACE_LEVEL log_level, char *to_be_sent, int length);
  31. /**
  32. * wlan_logging_set_flush_timer() - Sets the time period for log flush timer
  33. * @milliseconds: Time period in milliseconds
  34. *
  35. * This function sets the time period interval during which the log buffers
  36. * will be flushed out to user space. Setting this interval can set an
  37. * approximate maximum delay after which any message logged through QDF_TRACE
  38. * will appear at user-space
  39. *
  40. * Return: void
  41. */
  42. int wlan_logging_set_flush_timer(uint32_t milliseconds);
  43. /**
  44. * wlan_logging_notifier_init() - registers to panic notifier chain
  45. * @dump_at_kernel_enable: qdf logging at kernel level enabled
  46. *
  47. * This function registers an handler to panic notifier chain if
  48. * qdf logging at kernel level is disabled.
  49. *
  50. * Return: 0 on success
  51. */
  52. int wlan_logging_notifier_init(bool dump_at_kernel_enable);
  53. /**
  54. * wlan_logging_notifier_deinit() - unregisters to panic notifier chain
  55. * @dump_at_kernel_enable: qdf logging at kernel level enabled
  56. *
  57. * This function unregisters an handler to panic notifier chain if
  58. * qdf logging at kernel level is disabled.
  59. *
  60. * Return: 0 on success
  61. */
  62. int wlan_logging_notifier_deinit(bool dump_at_kernel_enable);
  63. #ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
  64. /**
  65. * wlan_logging_wait_for_flush_log_completion() - Wait for flush log completion
  66. *
  67. * Return: QDF_STATUS
  68. */
  69. QDF_STATUS wlan_logging_wait_for_flush_log_completion(void);
  70. void wlan_logging_set_per_pkt_stats(void);
  71. void wlan_logging_set_fw_flush_complete(void);
  72. void wlan_flush_host_logs_for_fatal(void);
  73. void wlan_logging_set_active(bool active);
  74. void wlan_set_console_log_levels(uint32_t console_log_levels);
  75. #else
  76. static inline QDF_STATUS wlan_logging_wait_for_flush_log_completion(void)
  77. {
  78. return QDF_STATUS_SUCCESS;
  79. }
  80. static inline void wlan_flush_host_logs_for_fatal(void) {}
  81. static inline void wlan_logging_set_per_pkt_stats(void) {}
  82. static inline void wlan_logging_set_fw_flush_complete(void) {}
  83. static inline void wlan_logging_set_active(bool active) {}
  84. static inline void wlan_set_console_log_levels(uint32_t console_log_levels) {}
  85. #endif /* WLAN_LOGGING_SOCK_SVC_ENABLE */
  86. #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && \
  87. defined(FEATURE_PKTLOG) && !defined(REMOVE_PKT_LOG)
  88. /**
  89. * wlan_deregister_txrx_packetdump() - tx/rx packet dump
  90. * deregistration
  91. * @pdev_id: id of the datapath pdev handle
  92. *
  93. * This function is used to deregister tx/rx packet dump callbacks
  94. * with ol, pe and htt layers
  95. *
  96. * Return: None
  97. *
  98. */
  99. void wlan_deregister_txrx_packetdump(uint8_t pdev_id);
  100. /**
  101. * wlan_register_txrx_packetdump() - tx/rx packet dump
  102. * registration
  103. * @pdev_id: id of the datapath pdev handle
  104. *
  105. * This function is used to register tx/rx packet dump callbacks
  106. * with ol, pe and htt layers
  107. *
  108. * Return: None
  109. *
  110. */
  111. void wlan_register_txrx_packetdump(uint8_t pdev_id);
  112. #else
  113. static inline void wlan_deregister_txrx_packetdump(uint8_t pdev_id) {}
  114. static inline void wlan_register_txrx_packetdump(uint8_t pdev_id) {}
  115. #endif
  116. #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && defined(FEATURE_WLAN_DIAG_SUPPORT)
  117. void wlan_report_log_completion(uint32_t is_fatal,
  118. uint32_t indicator,
  119. uint32_t reason_code,
  120. uint8_t ring_id);
  121. #else
  122. static inline void wlan_report_log_completion(uint32_t is_fatal,
  123. uint32_t indicator,
  124. uint32_t reason_code,
  125. uint8_t ring_id)
  126. {
  127. return;
  128. }
  129. #endif /* FEATURE_WLAN_DIAG_SUPPORT */
  130. #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && \
  131. defined(FEATURE_PKTLOG) && !defined(REMOVE_PKT_LOG)
  132. void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data);
  133. #else
  134. static inline
  135. void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data)
  136. {
  137. }
  138. #endif
  139. /**
  140. * enum tx_status - tx status
  141. * @tx_status_ok: successfully sent + acked
  142. * @tx_status_discard: discard - not sent (congestion control)
  143. * @tx_status_no_ack: no_ack - sent, but no ack
  144. * @tx_status_download_fail: download_fail -
  145. * the host could not deliver the tx frame to the target
  146. * @tx_status_peer_del: peer_del - tx completion for
  147. * already deleted peer used for HL case
  148. *
  149. * This enum has tx status types
  150. */
  151. enum tx_status {
  152. tx_status_ok,
  153. tx_status_discard,
  154. tx_status_no_ack,
  155. tx_status_download_fail,
  156. tx_status_peer_del,
  157. };
  158. #endif /* WLAN_LOGGING_SOCK_SVC_H */