1 /* 2 * Debug/trace/assert driver definitions for Dongle Host Driver. 3 * 4 * Copyright (C) 2020, Broadcom. 5 * 6 * Unless you and Broadcom execute a separate written software license 7 * agreement governing use of this software, this software is licensed to you 8 * under the terms of the GNU General Public License version 2 (the "GPL"), 9 * available at http://www.broadcom.com/licenses/GPLv2.php, with the 10 * following added to such license: 11 * 12 * As a special exception, the copyright holders of this software give you 13 * permission to link this software with independent modules, and to copy and 14 * distribute the resulting executable under terms of your choice, provided that 15 * you also meet, for each linked independent module, the terms and conditions of 16 * the license of that module. An independent module is a module which is not 17 * derived from this software. The special exception does not apply to any 18 * modifications of the software. 19 * 20 * 21 * <<Broadcom-WL-IPTag/Open:>> 22 * 23 * $Id$ 24 */ 25 26 #ifndef _dhd_dbg_ 27 #define _dhd_dbg_ 28 29 #if defined(NDIS) 30 #include "wl_nddbg.h" 31 #endif /* defined(NDIS) */ 32 33 #ifdef DHD_LOG_DUMP 34 extern char *dhd_log_dump_get_timestamp(void); 35 #ifdef DHD_EFI 36 /* FW verbose/console output to FW ring buffer */ 37 extern void dhd_log_dump_print(const char *fmt, ...); 38 /* DHD verbose/console output to DHD ring buffer */ 39 extern void dhd_log_dump_print_drv(const char *fmt, ...); 40 #define DHD_LOG_DUMP_WRITE(fmt, ...) dhd_log_dump_print_drv(fmt, ##__VA_ARGS__) 41 #define DHD_LOG_DUMP_WRITE_FW(fmt, ...) dhd_log_dump_print(fmt, ##__VA_ARGS__) 42 #else 43 #ifndef _DHD_LOG_DUMP_DEFINITIONS_ 44 #define _DHD_LOG_DUMP_DEFINITIONS_ 45 #define GENERAL_LOG_HDR "\n-------------------- General log ---------------------------\n" 46 #define PRESERVE_LOG_HDR "\n-------------------- Preserve log ---------------------------\n" 47 #define SPECIAL_LOG_HDR "\n-------------------- Special log ---------------------------\n" 48 #define DHD_DUMP_LOG_HDR "\n-------------------- 'dhd dump' log -----------------------\n" 49 #define EXT_TRAP_LOG_HDR "\n-------------------- Extended trap data -------------------\n" 50 #define HEALTH_CHK_LOG_HDR "\n-------------------- Health check data --------------------\n" 51 #ifdef DHD_DUMP_PCIE_RINGS 52 #define FLOWRING_DUMP_HDR "\n-------------------- Flowring dump --------------------\n" 53 #endif /* DHD_DUMP_PCIE_RINGS */ 54 #define DHD_LOG_DUMP_DLD(fmt, ...) \ 55 dhd_log_dump_write(DLD_BUF_TYPE_GENERAL, NULL, 0, fmt, ##__VA_ARGS__) 56 #define DHD_LOG_DUMP_DLD_EX(fmt, ...) \ 57 dhd_log_dump_write(DLD_BUF_TYPE_SPECIAL, NULL, 0, fmt, ##__VA_ARGS__) 58 #define DHD_LOG_DUMP_DLD_PRSRV(fmt, ...) \ 59 dhd_log_dump_write(DLD_BUF_TYPE_PRESERVE, NULL, 0, fmt, ##__VA_ARGS__) 60 #endif /* !_DHD_LOG_DUMP_DEFINITIONS_ */ 61 62 #ifndef DHD_LOG_DUMP_RING_DEFINITIONS 63 #define DHD_LOG_DUMP_RING_DEFINITIONS 64 #ifdef DHD_DEBUGABILITY_LOG_DUMP_RING 65 /* Enabled DHD_DEBUGABILITY_LOG_DUMP_RING */ 66 extern void dhd_dbg_ring_write(int type, char *binary_data, 67 int binary_len, const char *fmt, ...); 68 extern char* dhd_dbg_get_system_timestamp(void); 69 #define DHD_DBG_RING(fmt, ...) \ 70 dhd_dbg_ring_write(DRIVER_LOG_RING_ID, NULL, 0, fmt, ##__VA_ARGS__) 71 #define DHD_DBG_RING_EX(fmt, ...) \ 72 dhd_dbg_ring_write(FW_VERBOSE_RING_ID, NULL, 0, fmt, ##__VA_ARGS__) 73 #define DHD_DBG_RING_ROAM(fmt, ...) \ 74 dhd_dbg_ring_write(ROAM_STATS_RING_ID, NULL, 0, fmt, ##__VA_ARGS__) 75 76 #define DHD_LOG_DUMP_WRITE DHD_DBG_RING 77 #define DHD_LOG_DUMP_WRITE_EX DHD_DBG_RING_EX 78 #define DHD_LOG_DUMP_WRITE_PRSRV DHD_DBG_RING 79 #define DHD_LOG_DUMP_WRITE_ROAM DHD_DBG_RING_ROAM 80 81 #define DHD_PREFIX_TS "[%s][%s]: ", dhd_dbg_get_system_timestamp(), dhd_log_dump_get_timestamp() 82 #define DHD_PREFIX_TS_FN DHD_PREFIX_TS 83 #define DHD_LOG_DUMP_WRITE_TS DHD_DBG_RING(DHD_PREFIX_TS) 84 #define DHD_LOG_DUMP_WRITE_TS_FN DHD_DBG_RING(DHD_PREFIX_TS_FN) 85 #define DHD_LOG_DUMP_WRITE_EX_TS DHD_DBG_RING_EX(DHD_PREFIX_TS) 86 #define DHD_LOG_DUMP_WRITE_EX_TS_FN DHD_DBG_RING_EX(DHD_PREFIX_TS_FN) 87 #define DHD_LOG_DUMP_WRITE_PRSRV_TS DHD_DBG_RING(DHD_PREFIX_TS) 88 #define DHD_LOG_DUMP_WRITE_PRSRV_TS_FN DHD_DBG_RING(DHD_PREFIX_TS_FN) 89 #define DHD_LOG_DUMP_WRITE_ROAM_TS DHD_DBG_RING_ROAM(DHD_PREFIX_TS) 90 #define DHD_LOG_DUMP_WRITE_ROAM_TS_FN DHD_DBG_RING_ROAM(DHD_PREFIX_TS_FN) 91 #else 92 /* Not enabled DHD_DEBUGABILITY_LOG_DUMP_RING */ 93 #define DHD_LOG_DUMP_WRITE DHD_LOG_DUMP_DLD 94 #define DHD_LOG_DUMP_WRITE_EX DHD_LOG_DUMP_DLD_EX 95 #define DHD_LOG_DUMP_WRITE_PRSRV DHD_LOG_DUMP_DLD_PRSRV 96 #define DHD_LOG_DUMP_WRITE_ROAM DHD_LOG_DUMP_DLD 97 98 #define DHD_PREFIX_TS "[%s]: ", dhd_log_dump_get_timestamp() 99 #define DHD_PREFIX_TS_FN "[%s] %s: ", dhd_log_dump_get_timestamp(), __func__ 100 #define DHD_LOG_DUMP_WRITE_TS DHD_LOG_DUMP_DLD(DHD_PREFIX_TS) 101 #define DHD_LOG_DUMP_WRITE_TS_FN DHD_LOG_DUMP_DLD(DHD_PREFIX_TS_FN) 102 #define DHD_LOG_DUMP_WRITE_EX_TS DHD_LOG_DUMP_DLD_EX(DHD_PREFIX_TS) 103 #define DHD_LOG_DUMP_WRITE_EX_TS_FN DHD_LOG_DUMP_DLD_EX(DHD_PREFIX_TS_FN) 104 #define DHD_LOG_DUMP_WRITE_PRSRV_TS DHD_LOG_DUMP_DLD_PRSRV(DHD_PREFIX_TS) 105 #define DHD_LOG_DUMP_WRITE_PRSRV_TS_FN DHD_LOG_DUMP_DLD_PRSRV(DHD_PREFIX_TS_FN) 106 #define DHD_LOG_DUMP_WRITE_ROAM_TS DHD_LOG_DUMP_DLD(DHD_PREFIX_TS) 107 #define DHD_LOG_DUMP_WRITE_ROAM_TS_FN DHD_LOG_DUMP_DLD(DHD_PREFIX_TS_FN) 108 #endif /* DHD_DEBUGABILITY_LOG_DUMP_RING */ 109 #endif /* DHD_LOG_DUMP_RING_DEFINITIONS */ 110 111 #endif /* DHD_EFI */ 112 #define CONCISE_DUMP_BUFLEN 32 * 1024 113 #define ECNTRS_LOG_HDR "\n-------------------- Ecounters log --------------------------\n" 114 #ifdef DHD_STATUS_LOGGING 115 #define STATUS_LOG_HDR "\n-------------------- Status log -----------------------\n" 116 #endif /* DHD_STATUS_LOGGING */ 117 #define RTT_LOG_HDR "\n-------------------- RTT log --------------------------\n" 118 #define BCM_TRACE_LOG_HDR "\n-------------------- BCM Trace log --------------------------\n" 119 #define COOKIE_LOG_HDR "\n-------------------- Cookie List ----------------------------\n" 120 #endif /* DHD_LOG_DUMP */ 121 122 #if defined(CUSTOMER_DBG_SYSTEM_TIME) && defined(DHD_DEBUGABILITY_LOG_DUMP_RING) 123 #define DBG_PRINT_PREFIX "[%s][dhd][wlan]", dhd_dbg_get_system_timestamp() 124 #else 125 #define DBG_PRINT_PREFIX 126 #endif 127 #define DBG_PRINT_SYSTEM_TIME pr_cont(DBG_PRINT_PREFIX) 128 129 #if defined(BCMDBG) || defined(DHD_DEBUG) 130 131 #if defined(NDIS) 132 #define DHD_ERROR(args) do {if (dhd_msg_level & DHD_ERROR_VAL) \ 133 {printf args; DHD_NDDBG_OUTPUT args;}} while (0) 134 #define DHD_TRACE(args) do {if (dhd_msg_level & DHD_TRACE_VAL) \ 135 {printf args; DHD_NDDBG_OUTPUT args;}} while (0) 136 #define DHD_INFO(args) do {if (dhd_msg_level & DHD_INFO_VAL) \ 137 {printf args; DHD_NDDBG_OUTPUT args;}} while (0) 138 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 139 #else 140 /* NON-NDIS cases */ 141 #ifdef DHD_LOG_DUMP 142 #ifdef DHD_EFI 143 /* defined(DHD_EFI) && defined(DHD_LOG_DUMP) */ 144 #define DHD_ERROR(args) \ 145 do { \ 146 if (dhd_msg_level & DHD_ERROR_VAL) { \ 147 printf args; \ 148 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 149 DHD_LOG_DUMP_WRITE args; \ 150 } \ 151 } while (0) 152 153 #define DHD_INFO(args) \ 154 do { \ 155 if (dhd_msg_level & DHD_INFO_VAL) { \ 156 printf args; \ 157 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 158 DHD_LOG_DUMP_WRITE args; \ 159 } \ 160 } while (0) 161 #else /* DHD_EFI */ 162 /* !defined(DHD_EFI) and defined(DHD_LOG_DUMP) */ 163 #define DHD_ERROR(args) \ 164 do { \ 165 if (dhd_msg_level & DHD_ERROR_VAL) { \ 166 printf args; \ 167 DHD_LOG_DUMP_WRITE_TS; \ 168 DHD_LOG_DUMP_WRITE args; \ 169 } \ 170 } while (0) 171 172 #define DHD_INFO(args) do {if (dhd_msg_level & DHD_INFO_VAL) printf args;} while (0) 173 #endif /* DHD_EFI */ 174 #else /* DHD_LOG_DUMP */ 175 /* !defined(DHD_LOG_DUMP cases) */ 176 #define DHD_ERROR(args) do {if (dhd_msg_level & DHD_ERROR_VAL) printf args;} while (0) 177 #define DHD_INFO(args) do {if (dhd_msg_level & DHD_INFO_VAL) printf args;} while (0) 178 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 179 #endif /* DHD_LOG_DUMP */ 180 181 #define DHD_TRACE(args) do {if (dhd_msg_level & DHD_TRACE_VAL) printf args;} while (0) 182 #endif /* defined(NDIS) */ 183 184 #ifdef DHD_LOG_DUMP 185 /* LOG_DUMP defines common to EFI and NON-EFI */ 186 #ifdef DHD_EFI 187 /* EFI builds with LOG DUMP enabled */ 188 #define DHD_ERROR_MEM(args) \ 189 do { \ 190 if (dhd_msg_level & DHD_ERROR_VAL) { \ 191 if (dhd_msg_level & DHD_ERROR_MEM_VAL) { \ 192 printf args; \ 193 } \ 194 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 195 DHD_LOG_DUMP_WRITE args; \ 196 } \ 197 } while (0) 198 #define DHD_IOVAR_MEM(args) \ 199 do { \ 200 if (dhd_msg_level & DHD_ERROR_VAL) { \ 201 if (dhd_msg_level & DHD_IOVAR_MEM_VAL) { \ 202 printf args; \ 203 } \ 204 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 205 DHD_LOG_DUMP_WRITE args; \ 206 } \ 207 } while (0) 208 #define DHD_LOG_MEM(args) \ 209 do { \ 210 if (dhd_msg_level & DHD_ERROR_VAL) { \ 211 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 212 DHD_LOG_DUMP_WRITE args; \ 213 } \ 214 } while (0) 215 216 #define DHD_EVENT(args) \ 217 do { \ 218 if (dhd_msg_level & DHD_EVENT_VAL) { \ 219 DHD_LOG_DUMP_WRITE_FW("[%s]: ", dhd_log_dump_get_timestamp()); \ 220 DHD_LOG_DUMP_WRITE_FW args; \ 221 } \ 222 } while (0) 223 #define DHD_ECNTR_LOG(args) DHD_EVENT(args) 224 #define DHD_ERROR_EX(args) DHD_ERROR(args) 225 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 226 #define DHD_MSGTRACE_LOG(args) \ 227 do { \ 228 if (dhd_msg_level & DHD_MSGTRACE_VAL) { \ 229 DHD_LOG_DUMP_WRITE_FW("[%s]: ", dhd_log_dump_get_timestamp()); \ 230 DHD_LOG_DUMP_WRITE_FW args; \ 231 } \ 232 } while (0) 233 #define DHD_PRSRV_MEM(args) DHD_EVENT(args) 234 #else 235 /* NON-EFI builds with LOG DUMP enabled */ 236 #define DHD_ERROR_MEM(args) \ 237 do { \ 238 if (dhd_msg_level & DHD_ERROR_VAL) { \ 239 if (dhd_msg_level & DHD_ERROR_MEM_VAL) { \ 240 printf args; \ 241 } \ 242 DHD_LOG_DUMP_WRITE args; \ 243 } \ 244 } while (0) 245 #define DHD_IOVAR_MEM(args) \ 246 do { \ 247 if (dhd_msg_level & DHD_ERROR_VAL) { \ 248 if (dhd_msg_level & DHD_IOVAR_MEM_VAL) { \ 249 printf args; \ 250 } \ 251 DHD_LOG_DUMP_WRITE args; \ 252 } \ 253 } while (0) 254 #define DHD_LOG_MEM(args) \ 255 do { \ 256 if (dhd_msg_level & DHD_ERROR_VAL) { \ 257 DHD_LOG_DUMP_WRITE args; \ 258 } \ 259 } while (0) 260 261 #define DHD_EVENT(args) \ 262 do { \ 263 if (dhd_msg_level & DHD_EVENT_VAL) { \ 264 printf args; \ 265 DHD_LOG_DUMP_WRITE_PRSRV_TS; \ 266 DHD_LOG_DUMP_WRITE_PRSRV args; \ 267 } \ 268 } while (0) 269 #define DHD_PRSRV_MEM(args) \ 270 do { \ 271 if (dhd_msg_level & DHD_EVENT_VAL) { \ 272 if (dhd_msg_level & DHD_PRSRV_MEM_VAL) { \ 273 printf args; \ 274 } \ 275 DHD_LOG_DUMP_WRITE_TS; \ 276 DHD_LOG_DUMP_WRITE args; \ 277 } \ 278 } while (0) 279 /* Re-using 'DHD_MSGTRACE_VAL' for controlling printing of ecounter binary event 280 * logs to console and debug dump -- need to cleanup in the future to use separate 281 * 'DHD_ECNTR_VAL' bitmap flag. 'DHD_MSGTRACE_VAL' will be defined only 282 * for non-android builds. 283 */ 284 #define DHD_ECNTR_LOG(args) \ 285 do { \ 286 if (dhd_msg_level & DHD_EVENT_VAL) { \ 287 if (dhd_msg_level & DHD_MSGTRACE_VAL) { \ 288 printf args; \ 289 DHD_LOG_DUMP_WRITE_TS; \ 290 DHD_LOG_DUMP_WRITE args; \ 291 } \ 292 } \ 293 } while (0) 294 #define DHD_ERROR_EX(args) \ 295 do { \ 296 if (dhd_msg_level & DHD_ERROR_VAL) { \ 297 printf args; \ 298 DHD_LOG_DUMP_WRITE_EX_TS; \ 299 DHD_LOG_DUMP_WRITE_EX args; \ 300 } \ 301 } while (0) 302 #define DHD_MSGTRACE_LOG(args) \ 303 do { \ 304 if (dhd_msg_level & DHD_MSGTRACE_VAL) { \ 305 printf args; \ 306 } \ 307 DHD_LOG_DUMP_WRITE_TS; \ 308 DHD_LOG_DUMP_WRITE args; \ 309 } while (0) 310 311 #define DHD_ERROR_ROAM(args) \ 312 do { \ 313 if (dhd_msg_level & DHD_ERROR_VAL) { \ 314 printf args; \ 315 DHD_LOG_DUMP_WRITE_ROAM_TS; \ 316 DHD_LOG_DUMP_WRITE_ROAM args; \ 317 } \ 318 } while (0) 319 #endif /* DHD_EFI */ 320 #else /* DHD_LOG_DUMP */ 321 /* !DHD_LOG_DUMP */ 322 #define DHD_MSGTRACE_LOG(args) do {if (dhd_msg_level & DHD_MSGTRACE_VAL) printf args;} while (0) 323 #define DHD_ERROR_MEM(args) DHD_ERROR(args) 324 #define DHD_IOVAR_MEM(args) DHD_ERROR(args) 325 #define DHD_LOG_MEM(args) DHD_ERROR(args) 326 #define DHD_EVENT(args) do {if (dhd_msg_level & DHD_EVENT_VAL) printf args;} while (0) 327 #define DHD_ECNTR_LOG(args) DHD_EVENT(args) 328 #define DHD_PRSRV_MEM(args) DHD_EVENT(args) 329 #define DHD_ERROR_EX(args) DHD_ERROR(args) 330 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 331 #endif /* DHD_LOG_DUMP */ 332 333 #define DHD_DATA(args) do {if (dhd_msg_level & DHD_DATA_VAL) printf args;} while (0) 334 #define DHD_CTL(args) do {if (dhd_msg_level & DHD_CTL_VAL) printf args;} while (0) 335 #define DHD_TIMER(args) do {if (dhd_msg_level & DHD_TIMER_VAL) printf args;} while (0) 336 #define DHD_HDRS(args) do {if (dhd_msg_level & DHD_HDRS_VAL) printf args;} while (0) 337 #define DHD_BYTES(args) do {if (dhd_msg_level & DHD_BYTES_VAL) printf args;} while (0) 338 #define DHD_INTR(args) do {if (dhd_msg_level & DHD_INTR_VAL) printf args;} while (0) 339 #define DHD_GLOM(args) do {if (dhd_msg_level & DHD_GLOM_VAL) printf args;} while (0) 340 #define DHD_BTA(args) do {if (dhd_msg_level & DHD_BTA_VAL) printf args;} while (0) 341 #define DHD_ISCAN(args) do {if (dhd_msg_level & DHD_ISCAN_VAL) printf args;} while (0) 342 #define DHD_ARPOE(args) do {if (dhd_msg_level & DHD_ARPOE_VAL) printf args;} while (0) 343 #define DHD_REORDER(args) do {if (dhd_msg_level & DHD_REORDER_VAL) printf args;} while (0) 344 #define DHD_PNO(args) do {if (dhd_msg_level & DHD_PNO_VAL) printf args;} while (0) 345 #define DHD_RTT(args) do {if (dhd_msg_level & DHD_RTT_VAL) printf args;} while (0) 346 #define DHD_RPM(args) do {if (dhd_msg_level & DHD_RPM_VAL) printf args;} while (0) 347 #define DHD_PKT_MON(args) do {if (dhd_msg_level & DHD_PKT_MON_VAL) printf args;} while (0) 348 349 #if defined(DHD_LOG_DUMP) 350 #if defined(DHD_EFI) 351 #define DHD_FWLOG(args) DHD_MSGTRACE_LOG(args) 352 #elif defined(DHD_LOG_PRINT_RATE_LIMIT) 353 #define DHD_FW_VERBOSE(args) \ 354 do { \ 355 if (dbgring_msg_level & DHD_FWLOG_VAL) { \ 356 DHD_LOG_DUMP_WRITE_EX args; \ 357 } \ 358 } while (0) 359 #define DHD_FWLOG(args) \ 360 do { \ 361 if (dhd_msg_level & DHD_FWLOG_VAL) { \ 362 if (control_logtrace && !log_print_threshold) \ 363 printf args; \ 364 DHD_LOG_DUMP_WRITE args; \ 365 } \ 366 } while (0) 367 #else 368 #define DHD_FW_VERBOSE(args) \ 369 do { \ 370 if (dbgring_msg_level & DHD_FWLOG_VAL) { \ 371 DHD_LOG_DUMP_WRITE_EX args; \ 372 } \ 373 } while (0) 374 375 #define DHD_FWLOG(args) \ 376 do { \ 377 if (dhd_msg_level & DHD_FWLOG_VAL) { \ 378 if (control_logtrace) \ 379 printf args; \ 380 DHD_LOG_DUMP_WRITE args; \ 381 } \ 382 } while (0) 383 #endif /* DHD_EFI */ 384 #else /* DHD_LOG_DUMP */ 385 #if defined(NDIS) && (NDISVER >= 0x0630) 386 #define DHD_FWLOG(args) do {if (dhd_msg_level & DHD_FWLOG_VAL) \ 387 {printf args; DHD_NDDBG_OUTPUT args;}} while (0) 388 #else 389 #define DHD_FWLOG(args) do {if (dhd_msg_level & DHD_FWLOG_VAL) printf args;} while (0) 390 #endif /* defined(NDIS) && (NDISVER >= 0x0630) */ 391 #endif /* DHD_LOG_DUMP */ 392 393 #define DHD_DBGIF(args) do {if (dhd_msg_level & DHD_DBGIF_VAL) printf args;} while (0) 394 395 #ifdef DHD_PCIE_NATIVE_RUNTIMEPM 396 #define DHD_RPM(args) do {if (dhd_msg_level & DHD_RPM_VAL) printf args;} while (0) 397 #endif /* DHD_PCIE_NATIVE_RUNTIMEPM */ 398 399 #ifdef CUSTOMER_HW4_DEBUG 400 #define DHD_TRACE_HW4 DHD_ERROR 401 #define DHD_INFO_HW4 DHD_ERROR 402 #define DHD_ERROR_NO_HW4 DHD_INFO 403 #else 404 #define DHD_TRACE_HW4 DHD_TRACE 405 #define DHD_INFO_HW4 DHD_INFO 406 #define DHD_ERROR_NO_HW4 DHD_ERROR 407 #endif /* CUSTOMER_HW4_DEBUG */ 408 409 #define DHD_ERROR_ON() (dhd_msg_level & DHD_ERROR_VAL) 410 #define DHD_TRACE_ON() (dhd_msg_level & DHD_TRACE_VAL) 411 #define DHD_INFO_ON() (dhd_msg_level & DHD_INFO_VAL) 412 #define DHD_DATA_ON() (dhd_msg_level & DHD_DATA_VAL) 413 #define DHD_CTL_ON() (dhd_msg_level & DHD_CTL_VAL) 414 #define DHD_TIMER_ON() (dhd_msg_level & DHD_TIMER_VAL) 415 #define DHD_HDRS_ON() (dhd_msg_level & DHD_HDRS_VAL) 416 #define DHD_BYTES_ON() (dhd_msg_level & DHD_BYTES_VAL) 417 #define DHD_INTR_ON() (dhd_msg_level & DHD_INTR_VAL) 418 #define DHD_GLOM_ON() (dhd_msg_level & DHD_GLOM_VAL) 419 #define DHD_EVENT_ON() (dhd_msg_level & DHD_EVENT_VAL) 420 #define DHD_BTA_ON() (dhd_msg_level & DHD_BTA_VAL) 421 #define DHD_ISCAN_ON() (dhd_msg_level & DHD_ISCAN_VAL) 422 #define DHD_ARPOE_ON() (dhd_msg_level & DHD_ARPOE_VAL) 423 #define DHD_REORDER_ON() (dhd_msg_level & DHD_REORDER_VAL) 424 #define DHD_NOCHECKDIED_ON() (dhd_msg_level & DHD_NOCHECKDIED_VAL) 425 #define DHD_PNO_ON() (dhd_msg_level & DHD_PNO_VAL) 426 #define DHD_RTT_ON() (dhd_msg_level & DHD_RTT_VAL) 427 #define DHD_MSGTRACE_ON() (dhd_msg_level & DHD_MSGTRACE_VAL) 428 #define DHD_FWLOG_ON() (dhd_msg_level & DHD_FWLOG_VAL) 429 #define DHD_DBGIF_ON() (dhd_msg_level & DHD_DBGIF_VAL) 430 #define DHD_PKT_MON_ON() (dhd_msg_level & DHD_PKT_MON_VAL) 431 #define DHD_PKT_MON_DUMP_ON() (dhd_msg_level & DHD_PKT_MON_DUMP_VAL) 432 #ifdef DHD_PCIE_NATIVE_RUNTIMEPM 433 #define DHD_RPM_ON() (dhd_msg_level & DHD_RPM_VAL) 434 #endif /* DHD_PCIE_NATIVE_RUNTIMEPM */ 435 436 #else /* defined(BCMDBG) || defined(DHD_DEBUG) */ 437 438 #if defined(NDIS) 439 #define DHD_ERROR(args) do {if (dhd_msg_level & DHD_ERROR_VAL) \ 440 {printf args; DHD_NDDBG_OUTPUT args;}} while (0) 441 #define DHD_TRACE(args) do {if (dhd_msg_level & DHD_TRACE_VAL) \ 442 {DHD_NDDBG_OUTPUT args;}} while (0) 443 #define DHD_INFO(args) do {if (dhd_msg_level & DHD_INFO_VAL) \ 444 {DHD_NDDBG_OUTPUT args;}} while (0) 445 #elif defined(DHD_EFI) && defined(DHD_LOG_DUMP) 446 #define DHD_ERROR(args) \ 447 do { \ 448 if (dhd_msg_level & DHD_ERROR_VAL) { \ 449 printf args; \ 450 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 451 DHD_LOG_DUMP_WRITE args; \ 452 } \ 453 } while (0) 454 #define DHD_INFO(args) \ 455 do { \ 456 if (dhd_msg_level & DHD_INFO_VAL) { \ 457 printf args; \ 458 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 459 DHD_LOG_DUMP_WRITE args; \ 460 } \ 461 } while (0) 462 #define DHD_TRACE(args) 463 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 464 #else /* DHD_EFI && DHD_LOG_DUMP */ 465 466 #define DHD_ERROR(args) do {if (dhd_msg_level & DHD_ERROR_VAL) \ 467 printf args;} while (0) 468 #define DHD_TRACE(args) 469 #define DHD_INFO(args) 470 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 471 #endif /* defined(NDIS) */ 472 473 #define DHD_DATA(args) 474 #define DHD_CTL(args) 475 #define DHD_TIMER(args) 476 #define DHD_HDRS(args) 477 #define DHD_BYTES(args) 478 #define DHD_INTR(args) 479 #define DHD_GLOM(args) 480 481 #if defined(DHD_EFI) && defined(DHD_LOG_DUMP) 482 #define DHD_EVENT(args) \ 483 do { \ 484 if (dhd_msg_level & DHD_EVENT_VAL) { \ 485 DHD_LOG_DUMP_WRITE_FW("[%s]: ", dhd_log_dump_get_timestamp()); \ 486 DHD_LOG_DUMP_WRITE_FW args; \ 487 } \ 488 } while (0) 489 #define DHD_ECNTR_LOG(args) DHD_EVENT(args) 490 #else 491 #define DHD_EVENT(args) 492 #define DHD_ECNTR_LOG(args) DHD_EVENT(args) 493 #endif /* DHD_EFI && DHD_LOG_DUMP */ 494 495 #define DHD_PRSRV_MEM(args) DHD_EVENT(args) 496 497 #define DHD_BTA(args) 498 #define DHD_ISCAN(args) 499 #define DHD_ARPOE(args) 500 #define DHD_REORDER(args) 501 #define DHD_PNO(args) 502 #define DHD_RTT(args) 503 #define DHD_PKT_MON(args) 504 505 #if defined(DHD_EFI) && defined(DHD_LOG_DUMP) 506 #define DHD_MSGTRACE_LOG(args) \ 507 do { \ 508 if (dhd_msg_level & DHD_MSGTRACE_VAL) { \ 509 DHD_LOG_DUMP_WRITE_FW("[%s]: ", dhd_log_dump_get_timestamp()); \ 510 DHD_LOG_DUMP_WRITE_FW args; \ 511 } \ 512 } while (0) 513 #define DHD_FWLOG(args) DHD_MSGTRACE_LOG(args) 514 #else 515 #define DHD_MSGTRACE_LOG(args) 516 #define DHD_FWLOG(args) 517 #endif /* DHD_EFI && DHD_LOG_DUMP */ 518 519 #define DHD_DBGIF(args) 520 521 #if defined(DHD_EFI) && defined(DHD_LOG_DUMP) 522 #define DHD_ERROR_MEM(args) \ 523 do { \ 524 if (dhd_msg_level & DHD_ERROR_VAL) { \ 525 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 526 DHD_LOG_DUMP_WRITE args; \ 527 } \ 528 } while (0) 529 #define DHD_IOVAR_MEM(args) \ 530 do { \ 531 if (dhd_msg_level & DHD_ERROR_VAL) { \ 532 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 533 DHD_LOG_DUMP_WRITE args; \ 534 } \ 535 } while (0) 536 #define DHD_LOG_MEM(args) \ 537 do { \ 538 if (dhd_msg_level & DHD_ERROR_VAL) { \ 539 DHD_LOG_DUMP_WRITE("[%s]: ", dhd_log_dump_get_timestamp()); \ 540 DHD_LOG_DUMP_WRITE args; \ 541 } \ 542 } while (0) 543 #define DHD_ERROR_EX(args) DHD_ERROR(args) 544 #else 545 #define DHD_ERROR_MEM(args) DHD_ERROR(args) 546 #define DHD_IOVAR_MEM(args) DHD_ERROR(args) 547 #define DHD_LOG_MEM(args) DHD_ERROR(args) 548 #define DHD_ERROR_EX(args) DHD_ERROR(args) 549 #endif /* DHD_EFI */ 550 #define DHD_ERROR_ROAM(args) DHD_ERROR(args) 551 #ifdef CUSTOMER_HW4_DEBUG 552 #define DHD_TRACE_HW4 DHD_ERROR 553 #define DHD_INFO_HW4 DHD_ERROR 554 #define DHD_ERROR_NO_HW4 DHD_INFO 555 #else 556 #define DHD_TRACE_HW4 DHD_TRACE 557 #define DHD_INFO_HW4 DHD_INFO 558 #define DHD_ERROR_NO_HW4 DHD_ERROR 559 #endif /* CUSTOMER_HW4_DEBUG */ 560 561 #define DHD_ERROR_ON() 0 562 #define DHD_TRACE_ON() 0 563 #define DHD_INFO_ON() 0 564 #define DHD_DATA_ON() 0 565 #define DHD_CTL_ON() 0 566 #define DHD_TIMER_ON() 0 567 #define DHD_HDRS_ON() 0 568 #define DHD_BYTES_ON() 0 569 #define DHD_INTR_ON() 0 570 #define DHD_GLOM_ON() 0 571 #define DHD_EVENT_ON() 0 572 #define DHD_BTA_ON() 0 573 #define DHD_ISCAN_ON() 0 574 #define DHD_ARPOE_ON() 0 575 #define DHD_REORDER_ON() 0 576 #define DHD_NOCHECKDIED_ON() 0 577 #define DHD_PNO_ON() 0 578 #define DHD_RTT_ON() 0 579 #define DHD_PKT_MON_ON() 0 580 #define DHD_PKT_MON_DUMP_ON() 0 581 #define DHD_MSGTRACE_ON() 0 582 #define DHD_FWLOG_ON() 0 583 #define DHD_DBGIF_ON() 0 584 #ifdef DHD_PCIE_NATIVE_RUNTIMEPM 585 #define DHD_RPM_ON() 0 586 #endif /* DHD_PCIE_NATIVE_RUNTIMEPM */ 587 #endif /* defined(BCMDBG) || defined(DHD_DEBUG) */ 588 589 #define PRINT_RATE_LIMIT_PERIOD 5000000u /* 5s in units of us */ 590 #define DHD_ERROR_RLMT(args) \ 591 do { \ 592 if (dhd_msg_level & DHD_ERROR_VAL) { \ 593 static uint64 __err_ts = 0; \ 594 static uint32 __err_cnt = 0; \ 595 uint64 __cur_ts = 0; \ 596 __cur_ts = OSL_SYSUPTIME_US(); \ 597 if (__err_ts == 0 || (__cur_ts > __err_ts && \ 598 (__cur_ts - __err_ts > PRINT_RATE_LIMIT_PERIOD))) { \ 599 __err_ts = __cur_ts; \ 600 DHD_ERROR(args); \ 601 DHD_ERROR(("[Repeats %u times]\n", __err_cnt)); \ 602 __err_cnt = 0; \ 603 } else { \ 604 ++__err_cnt; \ 605 } \ 606 } \ 607 } while (0) 608 609 /* even in non-BCMDBG builds, logging of dongle iovars should be available */ 610 #define DHD_DNGL_IOVAR_SET(args) \ 611 do {if (dhd_msg_level & DHD_DNGL_IOVAR_SET_VAL) printf args;} while (0) 612 613 #ifdef BCMPERFSTATS 614 #define DHD_LOG(args) do {if (dhd_msg_level & DHD_LOG_VAL) bcmlog args;} while (0) 615 #else 616 #define DHD_LOG(args) 617 #endif 618 619 #if defined(BCMINTERNAL) && defined(LINUX) && defined(BCMSDIO) && (defined(BCMDBG) || \ 620 defined(DHD_DEBUG)) 621 extern void dhd_blog(char *cp, int size); 622 #define DHD_BLOG(cp, size) do { dhd_blog(cp, size);} while (0) 623 #else 624 #define DHD_BLOG(cp, size) 625 #endif 626 627 #define DHD_NONE(args) 628 extern int dhd_msg_level; 629 extern int dbgring_msg_level; 630 #ifdef DHD_LOG_PRINT_RATE_LIMIT 631 extern int log_print_threshold; 632 #endif /* DHD_LOG_PRINT_RATE_LIMIT */ 633 634 /* Defines msg bits */ 635 #include <dhdioctl.h> 636 637 #endif /* _dhd_dbg_ */ 638