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 #ifdef PROC_DEBUG
271 ssize_t proc_set_write_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
272 int proc_get_read_reg(struct seq_file *m, void *v);
273 ssize_t proc_set_read_reg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
274 
275 int proc_get_fwstate(struct seq_file *m, void *v);
276 int proc_get_sec_info(struct seq_file *m, void *v);
277 int proc_get_mlmext_state(struct seq_file *m, void *v);
278 
279 int proc_get_roam_flags(struct seq_file *m, void *v);
280 ssize_t proc_set_roam_flags(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
281 int proc_get_roam_param(struct seq_file *m, void *v);
282 ssize_t proc_set_roam_param(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
283 ssize_t proc_set_roam_tgt_addr(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
284 
285 int proc_get_qos_option(struct seq_file *m, void *v);
286 int proc_get_ht_option(struct seq_file *m, void *v);
287 int proc_get_rf_info(struct seq_file *m, void *v);
288 int proc_get_survey_info(struct seq_file *m, void *v);
289 int proc_get_ap_info(struct seq_file *m, void *v);
290 int proc_get_adapter_state(struct seq_file *m, void *v);
291 int proc_get_trx_info(struct seq_file *m, void *v);
292 int proc_get_rate_ctl(struct seq_file *m, void *v);
293 ssize_t proc_set_rate_ctl(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
294 int proc_get_suspend_resume_info(struct seq_file *m, void *v);
295 
296 ssize_t proc_set_fwdl_test_case(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
297 ssize_t proc_set_wait_hiq_empty(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
298 
299 int proc_get_all_sta_info(struct seq_file *m, void *v);
300 
301 int proc_get_rx_signal(struct seq_file *m, void *v);
302 ssize_t proc_set_rx_signal(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
303 int proc_get_hw_status(struct seq_file *m, void *v);
304 
305 int proc_get_ht_enable(struct seq_file *m, void *v);
306 ssize_t proc_set_ht_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
307 
308 int proc_get_bw_mode(struct seq_file *m, void *v);
309 ssize_t proc_set_bw_mode(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
310 
311 int proc_get_ampdu_enable(struct seq_file *m, void *v);
312 ssize_t proc_set_ampdu_enable(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
313 
314 int proc_get_rx_ampdu(struct seq_file *m, void *v);
315 ssize_t proc_set_rx_ampdu(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
316 
317 int proc_get_rx_stbc(struct seq_file *m, void *v);
318 ssize_t proc_set_rx_stbc(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
319 
320 int proc_get_en_fwps(struct seq_file *m, void *v);
321 ssize_t proc_set_en_fwps(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
322 
323 /* int proc_get_two_path_rssi(struct seq_file *m, void *v); */
324 int proc_get_rssi_disp(struct seq_file *m, void *v);
325 ssize_t proc_set_rssi_disp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
326 
327 int proc_get_btcoex_dbg(struct seq_file *m, void *v);
328 ssize_t proc_set_btcoex_dbg(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
329 int proc_get_btcoex_info(struct seq_file *m, void *v);
330 
331 int proc_get_odm_dbg_comp(struct seq_file *m, void *v);
332 ssize_t proc_set_odm_dbg_comp(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
333 int proc_get_odm_dbg_level(struct seq_file *m, void *v);
334 ssize_t proc_set_odm_dbg_level(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
335 
336 int proc_get_odm_adaptivity(struct seq_file *m, void *v);
337 ssize_t proc_set_odm_adaptivity(struct file *file, const char __user *buffer, size_t count, loff_t *pos, void *data);
338 
339 #ifdef CONFIG_DBG_COUNTER
340 int proc_get_rx_logs(struct seq_file *m, void *v);
341 int proc_get_tx_logs(struct seq_file *m, void *v);
342 int proc_get_int_logs(struct seq_file *m, void *v);
343 #endif
344 
345 #endif /* PROC_DEBUG */
346 
347 #endif	/* __RTW_DEBUG_H__ */
348