Mention branches and keyring.
[releases.git] / include / rtw_debug.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /******************************************************************************
3  *
4  * Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
5  *
6  ******************************************************************************/
7 #ifndef __RTW_DEBUG_H__
8 #define __RTW_DEBUG_H__
9
10 #include <linux/trace_seq.h>
11
12 #define _drv_always_            1
13 #define _drv_emerg_                     2
14 #define _drv_alert_                     3
15 #define _drv_crit_                      4
16 #define _drv_err_                       5
17 #define _drv_warning_           6
18 #define _drv_notice_            7
19 #define _drv_info_                      8
20 #define _drv_dump_                      9
21 #define _drv_debug_                     10
22
23
24 #define _module_rtl871x_xmit_c_         BIT(0)
25 #define _module_xmit_osdep_c_           BIT(1)
26 #define _module_rtl871x_recv_c_         BIT(2)
27 #define _module_recv_osdep_c_           BIT(3)
28 #define _module_rtl871x_mlme_c_         BIT(4)
29 #define _module_mlme_osdep_c_           BIT(5)
30 #define _module_rtl871x_sta_mgt_c_              BIT(6)
31 #define _module_rtl871x_cmd_c_                  BIT(7)
32 #define _module_cmd_osdep_c_            BIT(8)
33 #define _module_rtl871x_io_c_                           BIT(9)
34 #define _module_io_osdep_c_             BIT(10)
35 #define _module_os_intfs_c_                     BIT(11)
36 #define _module_rtl871x_security_c_             BIT(12)
37 #define _module_rtl871x_eeprom_c_                       BIT(13)
38 #define _module_hal_init_c_             BIT(14)
39 #define _module_hci_hal_init_c_         BIT(15)
40 #define _module_rtl871x_ioctl_c_                BIT(16)
41 #define _module_rtl871x_ioctl_set_c_            BIT(17)
42 #define _module_rtl871x_ioctl_query_c_  BIT(18)
43 #define _module_rtl871x_pwrctrl_c_                      BIT(19)
44 #define _module_hci_intfs_c_                    BIT(20)
45 #define _module_hci_ops_c_                      BIT(21)
46 #define _module_osdep_service_c_                        BIT(22)
47 #define _module_mp_                     BIT(23)
48 #define _module_hci_ops_os_c_                   BIT(24)
49 #define _module_rtl871x_ioctl_os_c              BIT(25)
50 #define _module_rtl8712_cmd_c_          BIT(26)
51 /* define _module_efuse_                        BIT(27) */
52 #define _module_rtl8192c_xmit_c_ BIT(28)
53 #define _module_hal_xmit_c_     BIT(28)
54 #define _module_efuse_                  BIT(29)
55 #define _module_rtl8712_recv_c_         BIT(30)
56 #define _module_rtl8712_led_c_          BIT(31)
57
58 #undef _MODULE_DEFINE_
59
60 #if defined _RTW_XMIT_C_
61         #define _MODULE_DEFINE_ _module_rtl871x_xmit_c_
62 #elif defined _XMIT_OSDEP_C_
63         #define _MODULE_DEFINE_ _module_xmit_osdep_c_
64 #elif defined _RTW_RECV_C_
65         #define _MODULE_DEFINE_ _module_rtl871x_recv_c_
66 #elif defined _RECV_OSDEP_C_
67         #define _MODULE_DEFINE_ _module_recv_osdep_c_
68 #elif defined _RTW_MLME_C_
69         #define _MODULE_DEFINE_ _module_rtl871x_mlme_c_
70 #elif defined _MLME_OSDEP_C_
71         #define _MODULE_DEFINE_ _module_mlme_osdep_c_
72 #elif defined _RTW_MLME_EXT_C_
73         #define _MODULE_DEFINE_ 1
74 #elif defined _RTW_STA_MGT_C_
75         #define _MODULE_DEFINE_ _module_rtl871x_sta_mgt_c_
76 #elif defined _RTW_CMD_C_
77         #define _MODULE_DEFINE_ _module_rtl871x_cmd_c_
78 #elif defined _CMD_OSDEP_C_
79         #define _MODULE_DEFINE_ _module_cmd_osdep_c_
80 #elif defined _RTW_IO_C_
81         #define _MODULE_DEFINE_ _module_rtl871x_io_c_
82 #elif defined _IO_OSDEP_C_
83         #define _MODULE_DEFINE_ _module_io_osdep_c_
84 #elif defined _OS_INTFS_C_
85         #define _MODULE_DEFINE_ _module_os_intfs_c_
86 #elif defined _RTW_SECURITY_C_
87         #define _MODULE_DEFINE_ _module_rtl871x_security_c_
88 #elif defined _RTW_EEPROM_C_
89         #define _MODULE_DEFINE_ _module_rtl871x_eeprom_c_
90 #elif defined _HAL_INTF_C_
91         #define _MODULE_DEFINE_ _module_hal_init_c_
92 #elif (defined _HCI_HAL_INIT_C_) || (defined _SDIO_HALINIT_C_)
93         #define _MODULE_DEFINE_ _module_hci_hal_init_c_
94 #elif defined _RTL871X_IOCTL_C_
95         #define _MODULE_DEFINE_ _module_rtl871x_ioctl_c_
96 #elif defined _RTL871X_IOCTL_SET_C_
97         #define _MODULE_DEFINE_ _module_rtl871x_ioctl_set_c_
98 #elif defined _RTL871X_IOCTL_QUERY_C_
99         #define _MODULE_DEFINE_ _module_rtl871x_ioctl_query_c_
100 #elif defined _RTL871X_PWRCTRL_C_
101         #define _MODULE_DEFINE_ _module_rtl871x_pwrctrl_c_
102 #elif defined _RTW_PWRCTRL_C_
103         #define _MODULE_DEFINE_ 1
104 #elif defined _HCI_INTF_C_
105         #define _MODULE_DEFINE_ _module_hci_intfs_c_
106 #elif defined _HCI_OPS_C_
107         #define _MODULE_DEFINE_ _module_hci_ops_c_
108 #elif defined _SDIO_OPS_C_
109         #define _MODULE_DEFINE_ 1
110 #elif defined _OSDEP_HCI_INTF_C_
111         #define _MODULE_DEFINE_ _module_hci_intfs_c_
112 #elif defined _OSDEP_SERVICE_C_
113         #define _MODULE_DEFINE_ _module_osdep_service_c_
114 #elif defined _HCI_OPS_OS_C_
115         #define _MODULE_DEFINE_ _module_hci_ops_os_c_
116 #elif defined _RTL871X_IOCTL_LINUX_C_
117         #define _MODULE_DEFINE_ _module_rtl871x_ioctl_os_c
118 #elif defined _RTL8712_CMD_C_
119         #define _MODULE_DEFINE_ _module_rtl8712_cmd_c_
120 #elif defined _RTL8192C_XMIT_C_
121         #define _MODULE_DEFINE_ 1
122 #elif defined _RTL8723AS_XMIT_C_
123         #define _MODULE_DEFINE_ 1
124 #elif defined _RTL8712_RECV_C_
125         #define _MODULE_DEFINE_ _module_rtl8712_recv_c_
126 #elif defined _RTL8192CU_RECV_C_
127         #define _MODULE_DEFINE_ _module_rtl8712_recv_c_
128 #elif defined _RTL871X_MLME_EXT_C_
129         #define _MODULE_DEFINE_ _module_mlme_osdep_c_
130 #elif defined _RTW_EFUSE_C_
131         #define _MODULE_DEFINE_ _module_efuse_
132 #endif
133
134 #define RT_TRACE(_Comp, _Level, Fmt) do {} while (0)
135 #define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen) do {} while (0)
136
137 #define DBG_871X(x, ...) do {} while (0)
138 #define MSG_8192C(x, ...) do {} while (0)
139 #define DBG_8192C(x, ...) do {} while (0)
140 #define DBG_871X_LEVEL(x, ...) do {} while (0)
141
142 #undef _dbgdump
143
144 #ifndef _RTL871X_DEBUG_C_
145         extern u32 GlobalDebugLevel;
146         extern u64 GlobalDebugComponents;
147 #endif
148
149 #define _dbgdump printk
150
151 #define DRIVER_PREFIX "RTL8723BS: "
152
153 #if defined(_dbgdump)
154
155 /* with driver-defined prefix */
156 #undef DBG_871X_LEVEL
157 #define DBG_871X_LEVEL(level, fmt, arg...)     \
158         do {\
159                 if (level <= GlobalDebugLevel) {\
160                         if (level <= _drv_err_ && level > _drv_always_) \
161                                 _dbgdump(DRIVER_PREFIX"ERROR " fmt, ##arg);\
162                         else \
163                                 _dbgdump(DRIVER_PREFIX fmt, ##arg);\
164                 } \
165         } while (0)
166
167 /* without driver-defined prefix */
168 #undef _DBG_871X_LEVEL
169 #define _DBG_871X_LEVEL(level, fmt, arg...)        \
170         do {\
171                 if (level <= GlobalDebugLevel) {\
172                         if (level <= _drv_err_ && level > _drv_always_) \
173                                 _dbgdump("ERROR " fmt, ##arg);\
174                         else \
175                                 _dbgdump(fmt, ##arg);\
176                 } \
177         } while (0)
178
179 #define RTW_DBGDUMP NULL /* 'stream' for _dbgdump */
180
181 /* dump message to selected 'stream' */
182 #define DBG_871X_SEL(sel, fmt, arg...)                                  \
183         do {                                                            \
184                 if (sel == RTW_DBGDUMP)                                 \
185                         _DBG_871X_LEVEL(_drv_always_, fmt, ##arg);      \
186                 else                                                    \
187                         seq_printf(sel, fmt, ##arg);                    \
188         } while (0)
189
190 /* dump message to selected 'stream' with driver-defined prefix */
191 #define DBG_871X_SEL_NL(sel, fmt, arg...)                               \
192         do {                                                            \
193                 if (sel == RTW_DBGDUMP)                                 \
194                         DBG_871X_LEVEL(_drv_always_, fmt, ##arg);       \
195                 else                                                    \
196                         seq_printf(sel, fmt, ##arg);                    \
197         } while (0)
198
199 #endif /* defined(_dbgdump) */
200
201 #ifdef DEBUG
202 #if     defined(_dbgdump)
203         #undef DBG_871X
204         #define DBG_871X(...)     do {\
205                 _dbgdump(DRIVER_PREFIX __VA_ARGS__);\
206         } while (0)
207
208         #undef MSG_8192C
209         #define MSG_8192C(...)     do {\
210                 _dbgdump(DRIVER_PREFIX __VA_ARGS__);\
211         } while (0)
212
213         #undef DBG_8192C
214         #define DBG_8192C(...)     do {\
215                 _dbgdump(DRIVER_PREFIX __VA_ARGS__);\
216         } while (0)
217 #endif /* defined(_dbgdump) */
218 #endif /* DEBUG */
219
220 #ifdef DEBUG_RTL871X
221
222 #if     defined(_dbgdump) && defined(_MODULE_DEFINE_)
223
224         #undef RT_TRACE
225         #define RT_TRACE(_Comp, _Level, Fmt)\
226         do {\
227                 if ((_Comp & GlobalDebugComponents) && (_Level <= GlobalDebugLevel)) {\
228                         _dbgdump("%s [0x%08x,%d]", DRIVER_PREFIX, (unsigned int)_Comp, _Level);\
229                         _dbgdump Fmt;\
230                 } \
231         } while (0)
232
233 #endif /* defined(_dbgdump) && defined(_MODULE_DEFINE_) */
234
235
236 #if     defined(_dbgdump)
237         #undef RT_PRINT_DATA
238         #define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen)                       \
239                 if (((_Comp) & GlobalDebugComponents) && (_Level <= GlobalDebugLevel))  \
240                 {                                                                       \
241                         int __i;                                                                \
242                         u8 *ptr = (u8 *)_HexData;                               \
243                         _dbgdump("%s", DRIVER_PREFIX);                                          \
244                         _dbgdump(_TitleString);                                         \
245                         for (__i = 0; __i < (int)_HexDataLen; __i++)                            \
246                         {                                                               \
247                                 _dbgdump("%02X%s", ptr[__i], (((__i + 1) % 4) == 0)?"  ":" ");  \
248                                 if (((__i + 1) % 16) == 0)      _dbgdump("\n");                 \
249                         }                                                               \
250                         _dbgdump("\n");                                                 \
251                 }
252 #endif /* defined(_dbgdump) */
253 #endif /* DEBUG_RTL871X */
254
255 #ifdef CONFIG_DBG_COUNTER
256 #define DBG_COUNTER(counter) counter++
257 #else
258 #define DBG_COUNTER(counter) do {} while (0)
259 #endif
260
261 void dump_drv_version(void *sel);
262 void dump_log_level(void *sel);
263
264 void sd_f0_reg_dump(void *sel, struct adapter *adapter);
265
266 void mac_reg_dump(void *sel, struct adapter *adapter);
267 void bb_reg_dump(void *sel, struct adapter *adapter);
268 void rf_reg_dump(void *sel, struct adapter *adapter);
269
270 #endif  /* __RTW_DEBUG_H__ */