123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- /*
- * Copyright (c) 2014-2021 The Linux Foundation. All rights reserved.
- * Copyright (c) 2022,2024 Qualcomm Innovation Center, Inc. All rights reserved.
- *
- * Permission to use, copy, modify, and/or distribute this software for
- * any purpose with or without fee is hereby granted, provided that the
- * above copyright notice and this permission notice appear in all
- * copies.
- *
- * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
- * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
- * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
- * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
- * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
- * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
- * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
- * PERFORMANCE OF THIS SOFTWARE.
- */
- /******************************************************************************
- * wlan_logging_sock_svc.h
- *
- ******************************************************************************/
- #ifndef WLAN_LOGGING_SOCK_SVC_H
- #define WLAN_LOGGING_SOCK_SVC_H
- #include <wlan_nlink_srv.h>
- #include <qdf_status.h>
- #include <qdf_trace.h>
- #include <wlan_nlink_common.h>
- int wlan_logging_sock_init_svc(void);
- int wlan_logging_sock_deinit_svc(void);
- int wlan_log_to_user(QDF_TRACE_LEVEL log_level, char *to_be_sent, int length);
- /**
- * wlan_logging_set_flush_timer() - Sets the time period for log flush timer
- * @milliseconds: Time period in milliseconds
- *
- * This function sets the time period interval during which the log buffers
- * will be flushed out to user space. Setting this interval can set an
- * approximate maximum delay after which any message logged through QDF_TRACE
- * will appear at user-space
- *
- * Return: void
- */
- int wlan_logging_set_flush_timer(uint32_t milliseconds);
- /**
- * wlan_logging_notifier_init() - registers to panic notifier chain
- * @dump_at_kernel_enable: qdf logging at kernel level enabled
- *
- * This function registers an handler to panic notifier chain if
- * qdf logging at kernel level is disabled.
- *
- * Return: 0 on success
- */
- int wlan_logging_notifier_init(bool dump_at_kernel_enable);
- /**
- * wlan_logging_notifier_deinit() - unregisters to panic notifier chain
- * @dump_at_kernel_enable: qdf logging at kernel level enabled
- *
- * This function unregisters an handler to panic notifier chain if
- * qdf logging at kernel level is disabled.
- *
- * Return: 0 on success
- */
- int wlan_logging_notifier_deinit(bool dump_at_kernel_enable);
- #ifdef WLAN_LOGGING_SOCK_SVC_ENABLE
- /**
- * wlan_logging_wait_for_flush_log_completion() - Wait for flush log completion
- *
- * Return: QDF_STATUS
- */
- QDF_STATUS wlan_logging_wait_for_flush_log_completion(void);
- void wlan_logging_set_per_pkt_stats(void);
- /**
- * wlan_logging_set_connectivity_log() - INterrupt the gwlan_logging thread
- * to send the connectivity logs
- *
- * Return: None
- */
- void wlan_logging_set_connectivity_log(void);
- void wlan_logging_set_fw_flush_complete(void);
- void wlan_flush_host_logs_for_fatal(void);
- void wlan_logging_set_active(bool active);
- void wlan_set_console_log_levels(uint32_t console_log_levels);
- #else
- static inline QDF_STATUS wlan_logging_wait_for_flush_log_completion(void)
- {
- return QDF_STATUS_SUCCESS;
- }
- static inline void wlan_flush_host_logs_for_fatal(void) {}
- static inline void wlan_logging_set_per_pkt_stats(void) {}
- static inline void wlan_logging_set_fw_flush_complete(void) {}
- static inline void wlan_logging_set_active(bool active) {}
- static inline void wlan_set_console_log_levels(uint32_t console_log_levels) {}
- #endif /* WLAN_LOGGING_SOCK_SVC_ENABLE */
- #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && \
- defined(CONNECTIVITY_PKTLOG)
- /**
- * wlan_deregister_txrx_packetdump() - tx/rx packet dump
- * deregistration
- * @pdev_id: id of the datapath pdev handle
- *
- * This function is used to deregister tx/rx packet dump callbacks
- * with ol, pe and htt layers
- *
- * Return: None
- *
- */
- void wlan_deregister_txrx_packetdump(uint8_t pdev_id);
- /**
- * wlan_register_txrx_packetdump() - tx/rx packet dump
- * registration
- * @pdev_id: id of the datapath pdev handle
- *
- * This function is used to register tx/rx packet dump callbacks
- * with ol, pe and htt layers
- *
- * Return: None
- *
- */
- void wlan_register_txrx_packetdump(uint8_t pdev_id);
- #else
- static inline void wlan_deregister_txrx_packetdump(uint8_t pdev_id) {}
- static inline void wlan_register_txrx_packetdump(uint8_t pdev_id) {}
- #endif
- #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && defined(FEATURE_WLAN_DIAG_SUPPORT)
- void wlan_report_log_completion(uint32_t is_fatal,
- uint32_t indicator,
- uint32_t reason_code,
- uint8_t ring_id);
- #else
- static inline void wlan_report_log_completion(uint32_t is_fatal,
- uint32_t indicator,
- uint32_t reason_code,
- uint8_t ring_id)
- {
- return;
- }
- #endif /* FEATURE_WLAN_DIAG_SUPPORT */
- #if defined(WLAN_LOGGING_SOCK_SVC_ENABLE) && \
- defined(CONNECTIVITY_PKTLOG)
- void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data);
- #else
- static inline
- void wlan_pkt_stats_to_logger_thread(void *pl_hdr, void *pkt_dump, void *data)
- {
- }
- #endif
- /**
- * enum tx_status - tx status
- * @tx_status_ok: successfully sent + acked
- * @tx_status_discard: discard - not sent (congestion control)
- * @tx_status_no_ack: no_ack - sent, but no ack
- * @tx_status_download_fail: download_fail -
- * the host could not deliver the tx frame to the target
- * @tx_status_peer_del: peer_del - tx completion for
- * already deleted peer used for HL case
- *
- * This enum has tx status types
- */
- enum tx_status {
- tx_status_ok,
- tx_status_discard,
- tx_status_no_ack,
- tx_status_download_fail,
- tx_status_peer_del,
- };
- #ifdef WLAN_CHIPSET_STATS
- void wlan_set_chipset_stats_bit(void);
- #else
- static inline void wlan_set_chipset_stats_bit(void)
- {
- }
- #endif /* WLAN_CHIPSET_STATS */
- #endif /* WLAN_LOGGING_SOCK_SVC_H */
|