1 /* Copyright (c) 2015, The Linux Foundation. All rights reserved. 2 * 3 * Redistribution and use in source and binary forms, with or without 4 * modification, are permitted provided that the following conditions 5 * are met: 6 * * Redistributions of source code must retain the above copyright 7 * notice, this list of conditions and the following disclaimer. 8 * * Redistributions in binary form must reproduce the above 9 * copyright notice, this list of conditions and the following 10 * disclaimer in the documentation and/or other materials provided 11 * with the distribution. 12 * * Neither the name of The Linux Foundation nor the names of its 13 * contributors may be used to endorse or promote products derived 14 * from this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 17 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 20 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 23 * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 25 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 26 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29 #ifndef __WIFI_HAL_WIFILOGGER_DIAG_H__ 30 #define __WIFI_HAL_WIFILOGGER_DIAG_H__ 31 32 #include "common.h" 33 #include "wifi_hal.h" 34 #include "wifilogger_event_defs.h" 35 36 #include <netlink/genl/genl.h> 37 #include <netlink/genl/family.h> 38 #include <netlink/genl/ctrl.h> 39 #include <linux/rtnetlink.h> 40 41 #define ANI_NL_MSG_BASE 0x10 /* Some arbitrary base */ 42 #define WIFI_HAL_USER_SOCK_PORT 646 43 #define WLAN_NL_MSG_CNSS_HOST_EVENT_LOG 17 44 #define ANI_NL_MSG_LOG_HOST_EVENT_LOG_TYPE 0x5050 45 #define ANI_NL_MSG_LOG_HOST_PRINT_TYPE 89 46 #define ANI_NL_MSG_LOG_FW_MSG_TYPE 92 47 48 #define WLAN_PKT_LOG_STATS 0x18E0 49 #define FEATURE_NOT_SUPPORTED 0xFF 50 51 /* 52 * - verbose_level 0 corresponds to no collection 53 * - verbose_level 1 correspond to normal log level, with minimal user impact. 54 * this is the default value 55 * - verbose_level 2 are enabled when user is lazily trying to reproduce a 56 problem, wifi performances and power 57 * can be impacted but device should not otherwise be significantly impacted 58 * - verbose_level 3+ are used when trying to actively debug a problem 59 */ 60 61 enum wifilogger_verbose_level { 62 VERBOSE_NO_COLLECTION, 63 VERBOSE_NORMAL_LOG, 64 VERBOSE_REPRO_PROBLEM, 65 VERBOSE_DEBUG_PROBLEM 66 }; 67 68 enum wifilogger_fw_diag_type { 69 DIAG_TYPE_FW_EVENT, /* send fw event- to diag*/ 70 DIAG_TYPE_FW_LOG, /* send log event- to diag*/ 71 DIAG_TYPE_FW_DEBUG_MSG, /* send dbg message- to diag*/ 72 DIAG_TYPE_FW_MSG = 4, /* send fw message- to diag*/ 73 }; 74 75 enum wifilogger_host_diag_type { 76 DIAG_TYPE_HOST_LOG_MSGS=1, 77 DIAG_TYPE_HOST_EVENTS=2, 78 }; 79 80 enum wlan_diag_frame_type { 81 WLAN_DIAG_TYPE_CONFIG, 82 WLAN_DIAG_TYPE_EVENT, /* Diag Events */ 83 WLAN_DIAG_TYPE_LOG, /* Diag Logs */ 84 WLAN_DIAG_TYPE_MSG, /* F3 messages */ 85 WLAN_DIAG_TYPE_LEGACY_MSG, 86 WLAN_DIAG_TYPE_EVENT_V2, 87 WLAN_DIAG_TYPE_LOG_V2, 88 WLAN_DIAG_TYPE_MSG_V2, 89 }; 90 91 typedef struct event_remap { 92 int q_event; 93 int g_event; 94 } event_remap_t; 95 96 typedef struct { 97 u32 diag_type; 98 u32 timestamp; 99 u32 length; 100 u32 dropped; 101 /* max ATH6KL_FWLOG_PAYLOAD_SIZE bytes */ 102 u_int8_t payload[0]; 103 }__attribute__((packed)) dbglog_slot; 104 105 typedef enum eAniNlModuleTypes { 106 ANI_NL_MSG_PUMAC = ANI_NL_MSG_BASE + 0x01, 107 ANI_NL_MSG_CNSS_DIAG = ANI_NL_MSG_BASE + 0x0B, 108 ANI_NL_MSG_LOG, 109 ANI_NL_MSG_MAX 110 } tAniNlModTypes; 111 112 //All Netlink messages must contain this header 113 typedef struct sAniHdr { 114 unsigned short type; 115 unsigned short length; 116 } tAniHdr, tAniMsgHdr; 117 118 typedef struct sAniCLDMsg { 119 int radio; // unit number of the radio 120 tAniHdr wmsg; // Airgo Message Header 121 } tAniCLDHdr; 122 123 /* 124 * This msg hdr will always follow tAniHdr in all the messages exchanged 125 * between the Applications in userspace the Pseudo Driver, in either 126 * direction. 127 */ 128 typedef struct sAniNlMsg { 129 struct nlmsghdr nlh; // Netlink Header 130 tAniCLDHdr clh; 131 } tAniNlHdr; 132 133 typedef struct sAniAppRegReq { 134 tAniNlModTypes type; /* The module id that the application is 135 registering for */ 136 int pid; /* Pid returned in the nl_sockaddr structure 137 in the call getsockbyname after the 138 application opens and binds a netlink 139 socket */ 140 } tAniNlAppRegReq; 141 142 typedef struct host_event_hdr_s 143 { 144 u16 event_id; 145 u16 length; 146 } host_event_hdr_t; 147 148 typedef struct fw_event_hdr_s 149 { 150 u16 diag_type; 151 u16 length; 152 } fw_event_hdr_t; 153 154 typedef struct 155 { 156 u32 reserved:24; 157 u32 diag_event_type:8; 158 }__attribute__((packed)) fw_diag_msg_fixed_hdr_t; 159 160 typedef struct 161 { 162 u32 timestamp:24; 163 u32 diag_event_type:8; 164 /* Below 16-bit field has different formats based on event type */ 165 union { 166 u16 payload_len; 167 struct { 168 u8 payload_len; 169 u8 vdev_level:3; 170 u8 vdev_id:5; 171 }__attribute__((packed)) msg_hdr; 172 }__attribute__((packed)) u; 173 u16 diag_id; 174 u8 payload[0]; 175 }__attribute__((packed)) fw_diag_msg_hdr_t; 176 177 typedef struct 178 { 179 u32 unused:24; 180 u32 diag_event_type:8; 181 u32 timestamp; 182 /* Below 16-bit field has different formats based on event type */ 183 union { 184 u16 payload_len; 185 struct { 186 u8 payload_len; 187 u8 vdev_level:3; 188 u8 vdev_id:5; 189 }__attribute__((packed)) msg_hdr; 190 }__attribute__((packed)) u; 191 u16 diag_id; 192 u8 payload[0]; 193 }__attribute__((packed)) fw_diag_msg_hdr_v2_t; 194 195 typedef struct wlan_wake_lock_event { 196 u32 status; 197 u32 reason; 198 u32 timeout; 199 u32 name_len; 200 char name[]; 201 } wlan_wake_lock_event_t; 202 203 enum log_event_type { 204 WLAN_LOG_TYPE_NON_FATAL, 205 WLAN_LOG_TYPE_FATAL, 206 }; 207 208 enum log_event_indicator { 209 WLAN_LOG_INDICATOR_UNUSED, 210 WLAN_LOG_INDICATOR_FRAMEWORK, 211 WLAN_LOG_INDICATOR_HOST_DRIVER, 212 WLAN_LOG_INDICATOR_FIRMWARE, 213 }; 214 215 enum log_event_host_reason_code { 216 WLAN_LOG_REASON_CODE_UNUSED, 217 WLAN_LOG_REASON_COMMAND_UNSUCCESSFUL, 218 WLAN_LOG_REASON_ROAM_FAIL, 219 WLAN_LOG_REASON_THREAD_STUCK, 220 WLAN_LOG_REASON_DATA_STALL, 221 WLAN_LOG_REASON_SME_COMMAND_STUCK, 222 WLAN_LOG_REASON_ZERO_SCAN_RESULTS, 223 WLAN_LOG_REASON_QUEUE_FULL, 224 WLAN_LOG_REASON_POWER_COLLAPSE_FAIL, 225 WLAN_LOG_REASON_SSR_FAIL, 226 WLAN_LOG_REASON_DISCONNECT_FAIL, 227 WLAN_LOG_REASON_CLEAN_UP_FAIL, 228 WLAN_LOG_REASON_MALLOC_FAIL, 229 WLAN_LOG_REASON_VOS_MSG_UNDER_RUN, 230 WLAN_LOG_REASON_MSG_POST_FAIL, 231 }; 232 233 typedef struct { 234 u32 is_fatal; 235 u32 indicator; 236 u32 reason_code; 237 u32 reserved; 238 } wlan_log_complete_event_t; 239 240 wifi_error diag_message_handler(hal_info *info, nl_msg *msg); 241 242 #endif /* __WIFI_HAL_WIFILOGGER_DIAG_H__ */ 243