hc
2024-01-05 071106ecf68c401173c58808b1cf5f68cc50d390
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/* SPDX-License-Identifier: GPL-2.0-only */
/*
 * This file is part of wl12xx
 *
 * Copyright (C) 2011 Texas Instruments. All rights reserved.
 * Copyright (C) 2008-2009 Nokia Corporation
 *
 * Contact: Luciano Coelho <coelho@ti.com>
 */
 
#ifndef __DEBUG_H__
#define __DEBUG_H__
 
#include <linux/bitops.h>
#include <linux/printk.h>
 
#define DRIVER_NAME "wlcore"
#define DRIVER_PREFIX DRIVER_NAME ": "
 
enum {
   DEBUG_NONE    = 0,
   DEBUG_IRQ    = BIT(0),
   DEBUG_SPI    = BIT(1),
   DEBUG_BOOT    = BIT(2),
   DEBUG_MAILBOX    = BIT(3),
   DEBUG_TESTMODE    = BIT(4),
   DEBUG_EVENT    = BIT(5),
   DEBUG_TX    = BIT(6),
   DEBUG_RX    = BIT(7),
   DEBUG_SCAN    = BIT(8),
   DEBUG_CRYPT    = BIT(9),
   DEBUG_PSM    = BIT(10),
   DEBUG_MAC80211    = BIT(11),
   DEBUG_CMD    = BIT(12),
   DEBUG_ACX    = BIT(13),
   DEBUG_SDIO    = BIT(14),
   DEBUG_FILTERS   = BIT(15),
   DEBUG_ADHOC     = BIT(16),
   DEBUG_AP    = BIT(17),
   DEBUG_PROBE    = BIT(18),
   DEBUG_IO    = BIT(19),
   DEBUG_MASTER    = (DEBUG_ADHOC | DEBUG_AP),
   DEBUG_ALL    = ~0,
};
 
extern u32 wl12xx_debug_level;
 
#define DEBUG_DUMP_LIMIT 1024
 
#define wl1271_error(fmt, arg...) \
   pr_err(DRIVER_PREFIX "ERROR " fmt "\n", ##arg)
 
#define wl1271_warning(fmt, arg...) \
   pr_warn(DRIVER_PREFIX "WARNING " fmt "\n", ##arg)
 
#define wl1271_notice(fmt, arg...) \
   pr_info(DRIVER_PREFIX fmt "\n", ##arg)
 
#define wl1271_info(fmt, arg...) \
   pr_info(DRIVER_PREFIX fmt "\n", ##arg)
 
/* define the debug macro differently if dynamic debug is supported */
#if defined(CONFIG_DYNAMIC_DEBUG)
#define wl1271_debug(level, fmt, arg...) \
   do { \
       if (unlikely(level & wl12xx_debug_level)) \
           dynamic_pr_debug(DRIVER_PREFIX fmt "\n", ##arg); \
   } while (0)
#else
#define wl1271_debug(level, fmt, arg...) \
   do { \
       if (unlikely(level & wl12xx_debug_level)) \
           printk(KERN_DEBUG pr_fmt(DRIVER_PREFIX fmt "\n"), \
                  ##arg); \
   } while (0)
#endif
 
#define wl1271_dump(level, prefix, buf, len)                      \
   do {                                      \
       if (level & wl12xx_debug_level)                      \
           print_hex_dump_debug(DRIVER_PREFIX prefix,          \
                   DUMP_PREFIX_OFFSET, 16, 1,          \
                   buf,                      \
                   min_t(size_t, len, DEBUG_DUMP_LIMIT), \
                   0);                      \
   } while (0)
 
#define wl1271_dump_ascii(level, prefix, buf, len)                  \
   do {                                      \
       if (level & wl12xx_debug_level)                      \
           print_hex_dump_debug(DRIVER_PREFIX prefix,          \
                   DUMP_PREFIX_OFFSET, 16, 1,          \
                   buf,                      \
                   min_t(size_t, len, DEBUG_DUMP_LIMIT), \
                   true);                      \
   } while (0)
 
#endif /* __DEBUG_H__ */