1 /* 2 * wpa_supplicant/hostapd / Debug prints 3 * Copyright (c) 2002-2007, Jouni Malinen <j (at) w1.fi> 4 * 5 * This program is free software; you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License version 2 as 7 * published by the Free Software Foundation. 8 * 9 * Alternatively, this software may be distributed under the terms of BSD 10 * license. 11 * 12 * See README and COPYING for more details. 13 */ 14 15 #ifndef WPA_DEBUG_H 16 #define WPA_DEBUG_H 17 18 #include "wpabuf.h" 19 20 /* Debugging function - conditional printf and hex dump. Driver wrappers can 21 * use these for debugging purposes. */ 22 23 enum { 24 MSG_EXCESSIVE, MSG_MSGDUMP, MSG_DEBUG, MSG_INFO, MSG_WARNING, MSG_ERROR 25 }; 26 27 #ifdef CONFIG_ANDROID_LOG 28 29 #define wpa_debug_print_timestamp() do {} while (0) 30 #define wpa_hexdump(...) do {} while (0) 31 #define wpa_hexdump_key(...) do {} while (0) 32 #define wpa_hexdump_buf(l,t,b) do {} while (0) 33 #define wpa_hexdump_buf_key(l,t,b) do {} while (0) 34 #define wpa_hexdump_ascii(...) do {} while (0) 35 #define wpa_hexdump_ascii_key(...) do {} while (0) 36 #define wpa_debug_open_file(...) do {} while (0) 37 #define wpa_debug_close_file() do {} while (0) 38 #define wpa_dbg(...) do {} while (0) 39 40 static inline int wpa_debug_reopen_file(void) 41 { 42 return 0; 43 } 44 45 46 void android_printf(int level, char *format, ...) 47 PRINTF_FORMAT(2, 3); 48 49 #define wpa_printf android_printf 50 51 #else /* CONFIG_ANDROID_LOG */ 52 53 #ifdef CONFIG_NO_STDOUT_DEBUG 54 55 #define wpa_debug_print_timestamp() do { } while (0) 56 #define wpa_printf(args...) do { } while (0) 57 #define wpa_hexdump(l,t,b,le) do { } while (0) 58 #define wpa_hexdump_buf(l,t,b) do { } while (0) 59 #define wpa_hexdump_key(l,t,b,le) do { } while (0) 60 #define wpa_hexdump_buf_key(l,t,b) do { } while (0) 61 #define wpa_hexdump_ascii(l,t,b,le) do { } while (0) 62 #define wpa_hexdump_ascii_key(l,t,b,le) do { } while (0) 63 #define wpa_debug_open_file(p) do { } while (0) 64 #define wpa_debug_close_file() do { } while (0) 65 #define wpa_dbg(args...) do { } while (0) 66 67 static inline int wpa_debug_reopen_file(void) 68 { 69 return 0; 70 } 71 72 #else /* CONFIG_NO_STDOUT_DEBUG */ 73 74 int wpa_debug_open_file(const char *path); 75 int wpa_debug_reopen_file(void); 76 void wpa_debug_close_file(void); 77 78 /** 79 * wpa_debug_printf_timestamp - Print timestamp for debug output 80 * 81 * This function prints a timestamp in seconds_from_1970.microsoconds 82 * format if debug output has been configured to include timestamps in debug 83 * messages. 84 */ 85 void wpa_debug_print_timestamp(void); 86 87 /** 88 * wpa_printf - conditional printf 89 * @level: priority level (MSG_*) of the message 90 * @fmt: printf format string, followed by optional arguments 91 * 92 * This function is used to print conditional debugging and error messages. The 93 * output may be directed to stdout, stderr, and/or syslog based on 94 * configuration. 95 * 96 * Note: New line '\n' is added to the end of the text when printing to stdout. 97 */ 98 void wpa_printf(int level, const char *fmt, ...) 99 PRINTF_FORMAT(2, 3); 100 101 /** 102 * wpa_hexdump - conditional hex dump 103 * @level: priority level (MSG_*) of the message 104 * @title: title of for the message 105 * @buf: data buffer to be dumped 106 * @len: length of the buf 107 * 108 * This function is used to print conditional debugging and error messages. The 109 * output may be directed to stdout, stderr, and/or syslog based on 110 * configuration. The contents of buf is printed out has hex dump. 111 */ 112 void wpa_hexdump(int level, const char *title, const u8 *buf, size_t len); 113 114 static inline void wpa_hexdump_buf(int level, const char *title, 115 const struct wpabuf *buf) 116 { 117 wpa_hexdump(level, title, buf ? wpabuf_head(buf) : NULL, 118 buf ? wpabuf_len(buf) : 0); 119 } 120 121 /** 122 * wpa_hexdump_key - conditional hex dump, hide keys 123 * @level: priority level (MSG_*) of the message 124 * @title: title of for the message 125 * @buf: data buffer to be dumped 126 * @len: length of the buf 127 * 128 * This function is used to print conditional debugging and error messages. The 129 * output may be directed to stdout, stderr, and/or syslog based on 130 * configuration. The contents of buf is printed out has hex dump. This works 131 * like wpa_hexdump(), but by default, does not include secret keys (passwords, 132 * etc.) in debug output. 133 */ 134 void wpa_hexdump_key(int level, const char *title, const u8 *buf, size_t len); 135 136 static inline void wpa_hexdump_buf_key(int level, const char *title, 137 const struct wpabuf *buf) 138 { 139 wpa_hexdump_key(level, title, buf ? wpabuf_head(buf) : 0, 140 buf ? wpabuf_len(buf) : 0); 141 } 142 143 /** 144 * wpa_hexdump_ascii - conditional hex dump 145 * @level: priority level (MSG_*) of the message 146 * @title: title of for the message 147 * @buf: data buffer to be dumped 148 * @len: length of the buf 149 * 150 * This function is used to print conditional debugging and error messages. The 151 * output may be directed to stdout, stderr, and/or syslog based on 152 * configuration. The contents of buf is printed out has hex dump with both 153 * the hex numbers and ASCII characters (for printable range) are shown. 16 154 * bytes per line will be shown. 155 */ 156 void wpa_hexdump_ascii(int level, const char *title, const u8 *buf, 157 size_t len); 158 159 /** 160 * wpa_hexdump_ascii_key - conditional hex dump, hide keys 161 * @level: priority level (MSG_*) of the message 162 * @title: title of for the message 163 * @buf: data buffer to be dumped 164 * @len: length of the buf 165 * 166 * This function is used to print conditional debugging and error messages. The 167 * output may be directed to stdout, stderr, and/or syslog based on 168 * configuration. The contents of buf is printed out has hex dump with both 169 * the hex numbers and ASCII characters (for printable range) are shown. 16 170 * bytes per line will be shown. This works like wpa_hexdump_ascii(), but by 171 * default, does not include secret keys (passwords, etc.) in debug output. 172 */ 173 void wpa_hexdump_ascii_key(int level, const char *title, const u8 *buf, 174 size_t len); 175 176 /* 177 * wpa_dbg() behaves like wpa_msg(), but it can be removed from build to reduce 178 * binary size. As such, it should be used with debugging messages that are not 179 * needed in the control interface while wpa_msg() has to be used for anything 180 * that needs to shown to control interface monitors. 181 */ 182 #define wpa_dbg(args...) wpa_msg(args) 183 184 #endif /* CONFIG_NO_STDOUT_DEBUG */ 185 186 #endif /* CONFIG_ANDROID_LOG */ 187 188 189 #ifdef CONFIG_NO_WPA_MSG 190 #define wpa_msg(args...) do { } while (0) 191 #define wpa_msg_ctrl(args...) do { } while (0) 192 #define wpa_msg_register_cb(f) do { } while (0) 193 #define wpa_msg_register_ifname_cb(f) do { } while (0) 194 #else /* CONFIG_NO_WPA_MSG */ 195 /** 196 * wpa_msg - Conditional printf for default target and ctrl_iface monitors 197 * @ctx: Pointer to context data; this is the ctx variable registered 198 * with struct wpa_driver_ops::init() 199 * @level: priority level (MSG_*) of the message 200 * @fmt: printf format string, followed by optional arguments 201 * 202 * This function is used to print conditional debugging and error messages. The 203 * output may be directed to stdout, stderr, and/or syslog based on 204 * configuration. This function is like wpa_printf(), but it also sends the 205 * same message to all attached ctrl_iface monitors. 206 * 207 * Note: New line '\n' is added to the end of the text when printing to stdout. 208 */ 209 void wpa_msg(void *ctx, int level, const char *fmt, ...) PRINTF_FORMAT(3, 4); 210 211 /** 212 * wpa_msg_ctrl - Conditional printf for ctrl_iface monitors 213 * @ctx: Pointer to context data; this is the ctx variable registered 214 * with struct wpa_driver_ops::init() 215 * @level: priority level (MSG_*) of the message 216 * @fmt: printf format string, followed by optional arguments 217 * 218 * This function is used to print conditional debugging and error messages. 219 * This function is like wpa_msg(), but it sends the output only to the 220 * attached ctrl_iface monitors. In other words, it can be used for frequent 221 * events that do not need to be sent to syslog. 222 */ 223 void wpa_msg_ctrl(void *ctx, int level, const char *fmt, ...) 224 PRINTF_FORMAT(3, 4); 225 226 typedef void (*wpa_msg_cb_func)(void *ctx, int level, const char *txt, 227 size_t len); 228 229 /** 230 * wpa_msg_register_cb - Register callback function for wpa_msg() messages 231 * @func: Callback function (%NULL to unregister) 232 */ 233 void wpa_msg_register_cb(wpa_msg_cb_func func); 234 235 typedef const char * (*wpa_msg_get_ifname_func)(void *ctx); 236 void wpa_msg_register_ifname_cb(wpa_msg_get_ifname_func func); 237 238 #endif /* CONFIG_NO_WPA_MSG */ 239 240 #ifdef CONFIG_NO_HOSTAPD_LOGGER 241 #define hostapd_logger(args...) do { } while (0) 242 #define hostapd_logger_register_cb(f) do { } while (0) 243 #else /* CONFIG_NO_HOSTAPD_LOGGER */ 244 void hostapd_logger(void *ctx, const u8 *addr, unsigned int module, int level, 245 const char *fmt, ...) PRINTF_FORMAT(5, 6); 246 247 typedef void (*hostapd_logger_cb_func)(void *ctx, const u8 *addr, 248 unsigned int module, int level, 249 const char *txt, size_t len); 250 251 /** 252 * hostapd_logger_register_cb - Register callback function for hostapd_logger() 253 * @func: Callback function (%NULL to unregister) 254 */ 255 void hostapd_logger_register_cb(hostapd_logger_cb_func func); 256 #endif /* CONFIG_NO_HOSTAPD_LOGGER */ 257 258 #define HOSTAPD_MODULE_IEEE80211 0x00000001 259 #define HOSTAPD_MODULE_IEEE8021X 0x00000002 260 #define HOSTAPD_MODULE_RADIUS 0x00000004 261 #define HOSTAPD_MODULE_WPA 0x00000008 262 #define HOSTAPD_MODULE_DRIVER 0x00000010 263 #define HOSTAPD_MODULE_IAPP 0x00000020 264 #define HOSTAPD_MODULE_MLME 0x00000040 265 266 enum hostapd_logger_level { 267 HOSTAPD_LEVEL_DEBUG_VERBOSE = 0, 268 HOSTAPD_LEVEL_DEBUG = 1, 269 HOSTAPD_LEVEL_INFO = 2, 270 HOSTAPD_LEVEL_NOTICE = 3, 271 HOSTAPD_LEVEL_WARNING = 4 272 }; 273 274 275 #ifdef CONFIG_DEBUG_SYSLOG 276 277 void wpa_debug_open_syslog(void); 278 void wpa_debug_close_syslog(void); 279 280 #else /* CONFIG_DEBUG_SYSLOG */ 281 282 static inline void wpa_debug_open_syslog(void) 283 { 284 } 285 286 static inline void wpa_debug_close_syslog(void) 287 { 288 } 289 290 #endif /* CONFIG_DEBUG_SYSLOG */ 291 292 293 #ifdef EAPOL_TEST 294 #define WPA_ASSERT(a) \ 295 do { \ 296 if (!(a)) { \ 297 printf("WPA_ASSERT FAILED '" #a "' " \ 298 "%s %s:%d\n", \ 299 __FUNCTION__, __FILE__, __LINE__); \ 300 exit(1); \ 301 } \ 302 } while (0) 303 #else 304 #define WPA_ASSERT(a) do { } while (0) 305 #endif 306 307 #endif /* WPA_DEBUG_H */ 308