1 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
2 /* Copyright(c) 2018-2019  Realtek Corporation
3  */
4 
5 #ifndef __RTW_DEBUG_H
6 #define __RTW_DEBUG_H
7 
8 enum rtw_debug_mask {
9 	RTW_DBG_PCI		= 0x00000001,
10 	RTW_DBG_TX		= 0x00000002,
11 	RTW_DBG_RX		= 0x00000004,
12 	RTW_DBG_PHY		= 0x00000008,
13 	RTW_DBG_FW		= 0x00000010,
14 	RTW_DBG_EFUSE		= 0x00000020,
15 	RTW_DBG_COEX		= 0x00000040,
16 	RTW_DBG_RFK		= 0x00000080,
17 	RTW_DBG_REGD		= 0x00000100,
18 	RTW_DBG_DEBUGFS		= 0x00000200,
19 	RTW_DBG_PS		= 0x00000400,
20 	RTW_DBG_BF		= 0x00000800,
21 	RTW_DBG_WOW		= 0x00001000,
22 	RTW_DBG_CFO		= 0x00002000,
23 	RTW_DBG_PATH_DIV	= 0x00004000,
24 	RTW_DBG_ADAPTIVITY	= 0x00008000,
25 	RTW_DBG_HW_SCAN		= 0x00010000,
26 	RTW_DBG_STATE		= 0x00020000,
27 	RTW_DBG_SDIO		= 0x00040000,
28 
29 	RTW_DBG_ALL		= 0xffffffff
30 };
31 
32 #ifdef CONFIG_RTW88_DEBUGFS
33 
34 void rtw_debugfs_init(struct rtw_dev *rtwdev);
35 void rtw_debugfs_get_simple_phy_info(struct seq_file *m);
36 
37 #else
38 
rtw_debugfs_init(struct rtw_dev * rtwdev)39 static inline void rtw_debugfs_init(struct rtw_dev *rtwdev) {}
40 
41 #endif /* CONFIG_RTW88_DEBUGFS */
42 
43 #ifdef CONFIG_RTW88_DEBUG
44 
45 __printf(3, 4)
46 void __rtw_dbg(struct rtw_dev *rtwdev, enum rtw_debug_mask mask,
47 	       const char *fmt, ...);
48 
49 #define rtw_dbg(rtwdev, a...) __rtw_dbg(rtwdev, ##a)
50 
51 #else
52 
rtw_dbg(struct rtw_dev * rtwdev,enum rtw_debug_mask mask,const char * fmt,...)53 static inline void rtw_dbg(struct rtw_dev *rtwdev, enum rtw_debug_mask mask,
54 			   const char *fmt, ...) {}
55 
56 #endif /* CONFIG_RTW88_DEBUG */
57 
58 #define rtw_info(rtwdev, a...) dev_info(rtwdev->dev, ##a)
59 #define rtw_warn(rtwdev, a...) dev_warn(rtwdev->dev, ##a)
60 #define rtw_err(rtwdev, a...) dev_err(rtwdev->dev, ##a)
61 
62 #endif
63