/* Copyright (c) 2015, The Linux Foundation. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * * Neither the name of The Linux Foundation nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef __WIFI_HAL_WIFILOGGER_DIAG_H__ #define __WIFI_HAL_WIFILOGGER_DIAG_H__ #include "common.h" #include "wifi_hal.h" #include "wifilogger_event_defs.h" #include <netlink/genl/genl.h> #include <netlink/genl/family.h> #include <netlink/genl/ctrl.h> #include <linux/rtnetlink.h> #define ANI_NL_MSG_BASE 0x10 /* Some arbitrary base */ #define WIFI_HAL_USER_SOCK_PORT 646 #define WLAN_NL_MSG_CNSS_HOST_EVENT_LOG 17 #define ANI_NL_MSG_LOG_HOST_EVENT_LOG_TYPE 0x5050 #define ANI_NL_MSG_LOG_HOST_PRINT_TYPE 89 #define ANI_NL_MSG_LOG_FW_MSG_TYPE 92 #define WLAN_PKT_LOG_STATS 0x18E0 #define FEATURE_NOT_SUPPORTED 0xFF /* * - verbose_level 0 corresponds to no collection * - verbose_level 1 correspond to normal log level, with minimal user impact. * this is the default value * - verbose_level 2 are enabled when user is lazily trying to reproduce a problem, wifi performances and power * can be impacted but device should not otherwise be significantly impacted * - verbose_level 3+ are used when trying to actively debug a problem */ enum wifilogger_verbose_level { VERBOSE_NO_COLLECTION, VERBOSE_NORMAL_LOG, VERBOSE_REPRO_PROBLEM, VERBOSE_DEBUG_PROBLEM }; enum wifilogger_fw_diag_type { DIAG_TYPE_FW_EVENT, /* send fw event- to diag*/ DIAG_TYPE_FW_LOG, /* send log event- to diag*/ DIAG_TYPE_FW_DEBUG_MSG, /* send dbg message- to diag*/ DIAG_TYPE_FW_MSG = 4, /* send fw message- to diag*/ }; enum wifilogger_host_diag_type { DIAG_TYPE_HOST_LOG_MSGS=1, DIAG_TYPE_HOST_EVENTS=2, }; enum wlan_diag_frame_type { WLAN_DIAG_TYPE_CONFIG, WLAN_DIAG_TYPE_EVENT, /* Diag Events */ WLAN_DIAG_TYPE_LOG, /* Diag Logs */ WLAN_DIAG_TYPE_MSG, /* F3 messages */ WLAN_DIAG_TYPE_LEGACY_MSG, }; static uint32_t get_le32(const uint8_t *pos) { return pos[0] | (pos[1] << 8) | (pos[2] << 16) | (pos[3] << 24); } typedef struct event_remap { int q_event; int g_event; } event_remap_t; typedef struct { u32 diag_type; u32 timestamp; u32 length; u32 dropped; /* max ATH6KL_FWLOG_PAYLOAD_SIZE bytes */ u_int8_t payload[0]; }__attribute__((packed)) dbglog_slot; typedef enum eAniNlModuleTypes { ANI_NL_MSG_PUMAC = ANI_NL_MSG_BASE + 0x01, ANI_NL_MSG_CNSS_DIAG = ANI_NL_MSG_BASE + 0x0B, ANI_NL_MSG_LOG, ANI_NL_MSG_MAX } tAniNlModTypes; //All Netlink messages must contain this header typedef struct sAniHdr { unsigned short type; unsigned short length; } tAniHdr, tAniMsgHdr; /* * This msg hdr will always follow tAniHdr in all the messages exchanged * between the Applications in userspace the Pseudo Driver, in either * direction. */ typedef struct sAniNlMsg { struct nlmsghdr nlh; // Netlink Header int radio; // unit number of the radio tAniHdr wmsg; // Airgo Message Header } tAniNlHdr; typedef struct sAniAppRegReq { tAniNlModTypes type; /* The module id that the application is registering for */ int pid; /* Pid returned in the nl_sockaddr structure in the call getsockbyname after the application opens and binds a netlink socket */ } tAniNlAppRegReq; typedef struct host_event_hdr_s { u16 event_id; u16 length; } host_event_hdr_t; typedef struct fw_event_hdr_s { u16 diag_type; u16 length; } fw_event_hdr_t; typedef struct { u32 timestamp:24; u32 diag_event_type:8; /* Below 16-bit field has different formats based on event type */ union { u16 payload_len; struct { u8 payload_len; u8 vdev_level:3; u8 vdev_id:5; }__attribute__((packed)) msg_hdr; }__attribute__((packed)) u; u16 diag_id; u8 payload[0]; }__attribute__((packed)) fw_diag_msg_hdr_t; typedef struct wlan_wake_lock_event { u32 status; u32 reason; u32 timeout; u32 name_len; char name[]; } wlan_wake_lock_event_t; enum log_event_type { WLAN_LOG_TYPE_NON_FATAL, WLAN_LOG_TYPE_FATAL, }; enum log_event_indicator { WLAN_LOG_INDICATOR_UNUSED, WLAN_LOG_INDICATOR_FRAMEWORK, WLAN_LOG_INDICATOR_HOST_DRIVER, WLAN_LOG_INDICATOR_FIRMWARE, }; enum log_event_host_reason_code { WLAN_LOG_REASON_CODE_UNUSED, WLAN_LOG_REASON_COMMAND_UNSUCCESSFUL, WLAN_LOG_REASON_ROAM_FAIL, WLAN_LOG_REASON_THREAD_STUCK, WLAN_LOG_REASON_DATA_STALL, WLAN_LOG_REASON_SME_COMMAND_STUCK, WLAN_LOG_REASON_ZERO_SCAN_RESULTS, WLAN_LOG_REASON_QUEUE_FULL, WLAN_LOG_REASON_POWER_COLLAPSE_FAIL, WLAN_LOG_REASON_SSR_FAIL, WLAN_LOG_REASON_DISCONNECT_FAIL, WLAN_LOG_REASON_CLEAN_UP_FAIL, WLAN_LOG_REASON_MALLOC_FAIL, WLAN_LOG_REASON_VOS_MSG_UNDER_RUN, WLAN_LOG_REASON_MSG_POST_FAIL, }; typedef struct { u32 is_fatal; u32 indicator; u32 reason_code; u32 reserved; } wlan_log_complete_event_t; wifi_error diag_message_handler(hal_info *info, nl_msg *msg); #endif /* __WIFI_HAL_WIFILOGGER_DIAG_H__ */