wlan_logging_sock_svc.h 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (c) 2014-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. * 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. #ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
  44. void wlan_logging_set_per_pkt_stats(void);
  45. void wlan_logging_set_fw_flush_complete(void);
  46. void wlan_flush_host_logs_for_fatal(void);
  47. void wlan_logging_set_active(bool active);
  48. void wlan_logging_set_log_to_console(bool log_to_console);
  49. #else
  50. static inline void wlan_flush_host_logs_for_fatal(void) {}
  51. static inline void wlan_logging_set_per_pkt_stats(void) {}
  52. static inline void wlan_logging_set_fw_flush_complete(void) {}
  53. static inline void wlan_logging_set_active(bool active) {}
  54. static inline void wlan_logging_set_log_to_console(bool log_to_console) {}
  55. #endif /* WLAN_LOGGING_SOCK_SVC_ENABLE */
  56. #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && !defined(REMOVE_PKT_LOG)
  57. void wlan_deregister_txrx_packetdump(void);
  58. void wlan_register_txrx_packetdump(void);
  59. #else
  60. static inline void wlan_deregister_txrx_packetdump(void) {}
  61. static inline void wlan_register_txrx_packetdump(void) {}
  62. #endif
  63. #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && defined(FEATURE_WLAN_DIAG_SUPPORT)
  64. void wlan_report_log_completion(uint32_t is_fatal,
  65. uint32_t indicator,
  66. uint32_t reason_code,
  67. uint8_t ring_id);
  68. #else
  69. static inline void wlan_report_log_completion(uint32_t is_fatal,
  70. uint32_t indicator,
  71. uint32_t reason_code,
  72. uint8_t ring_id)
  73. {
  74. return;
  75. }
  76. #endif /* FEATURE_WLAN_DIAG_SUPPORT */
  77. #if defined(CONFIG_MCL) && !defined(REMOVE_PKT_LOG)
  78. void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data);
  79. #else
  80. static inline
  81. void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data)
  82. {
  83. }
  84. #endif
  85. #endif /* WLAN_LOGGING_SOCK_SVC_H */