1daeccac2SArend van Spriel // SPDX-License-Identifier: ISC
205491d2cSKalle Valo /*
305491d2cSKalle Valo  * Copyright (c) 2010 Broadcom Corporation
405491d2cSKalle Valo  */
505491d2cSKalle Valo 
605491d2cSKalle Valo #ifndef BRCMFMAC_DEBUG_H
705491d2cSKalle Valo #define BRCMFMAC_DEBUG_H
805491d2cSKalle Valo 
9b4fd63c6SArend van Spriel #include <linux/net.h>	/* net_ratelimit() */
10b4fd63c6SArend van Spriel 
1105491d2cSKalle Valo /* message levels */
1205491d2cSKalle Valo #define BRCMF_TRACE_VAL		0x00000002
1305491d2cSKalle Valo #define BRCMF_INFO_VAL		0x00000004
1405491d2cSKalle Valo #define BRCMF_DATA_VAL		0x00000008
1505491d2cSKalle Valo #define BRCMF_CTL_VAL		0x00000010
1605491d2cSKalle Valo #define BRCMF_TIMER_VAL		0x00000020
1705491d2cSKalle Valo #define BRCMF_HDRS_VAL		0x00000040
1805491d2cSKalle Valo #define BRCMF_BYTES_VAL		0x00000080
1905491d2cSKalle Valo #define BRCMF_INTR_VAL		0x00000100
2005491d2cSKalle Valo #define BRCMF_GLOM_VAL		0x00000200
2105491d2cSKalle Valo #define BRCMF_EVENT_VAL		0x00000400
2205491d2cSKalle Valo #define BRCMF_BTA_VAL		0x00000800
2305491d2cSKalle Valo #define BRCMF_FIL_VAL		0x00001000
2405491d2cSKalle Valo #define BRCMF_USB_VAL		0x00002000
2505491d2cSKalle Valo #define BRCMF_SCAN_VAL		0x00004000
2605491d2cSKalle Valo #define BRCMF_CONN_VAL		0x00008000
2705491d2cSKalle Valo #define BRCMF_BCDC_VAL		0x00010000
2805491d2cSKalle Valo #define BRCMF_SDIO_VAL		0x00020000
2905491d2cSKalle Valo #define BRCMF_MSGBUF_VAL	0x00040000
3005491d2cSKalle Valo #define BRCMF_PCIE_VAL		0x00080000
3105491d2cSKalle Valo #define BRCMF_FWCON_VAL		0x00100000
3205491d2cSKalle Valo 
3305491d2cSKalle Valo /* set default print format */
3405491d2cSKalle Valo #undef pr_fmt
3505491d2cSKalle Valo #define pr_fmt(fmt)		KBUILD_MODNAME ": " fmt
3605491d2cSKalle Valo 
375cc898fbSRafał Miłecki struct brcmf_bus;
385cc898fbSRafał Miłecki 
395cc898fbSRafał Miłecki __printf(3, 4)
405cc898fbSRafał Miłecki void __brcmf_err(struct brcmf_bus *bus, const char *func, const char *fmt, ...);
41d0630555SRafał Miłecki /* Macro for error messages. When debugging / tracing the driver all error
42d0630555SRafał Miłecki  * messages are important to us.
4305491d2cSKalle Valo  */
448602e624SRafał Miłecki #ifndef brcmf_err
4505491d2cSKalle Valo #define brcmf_err(fmt, ...)						\
4605491d2cSKalle Valo 	do {								\
47d0630555SRafał Miłecki 		if (IS_ENABLED(CONFIG_BRCMDBG) ||			\
48d0630555SRafał Miłecki 		    IS_ENABLED(CONFIG_BRCM_TRACING) ||			\
49d0630555SRafał Miłecki 		    net_ratelimit())					\
505cc898fbSRafał Miłecki 			__brcmf_err(NULL, __func__, fmt, ##__VA_ARGS__);\
5105491d2cSKalle Valo 	} while (0)
528602e624SRafał Miłecki #endif
5305491d2cSKalle Valo 
5416e64676SRafał Miłecki #define bphy_err(drvr, fmt, ...)					\
553ef005b8SRafał Miłecki 	do {								\
563ef005b8SRafał Miłecki 		if (IS_ENABLED(CONFIG_BRCMDBG) ||			\
573ef005b8SRafał Miłecki 		    IS_ENABLED(CONFIG_BRCM_TRACING) ||			\
583ef005b8SRafał Miłecki 		    net_ratelimit())					\
5916e64676SRafał Miłecki 			wiphy_err((drvr)->wiphy, "%s: " fmt, __func__,	\
603ef005b8SRafał Miłecki 				  ##__VA_ARGS__);			\
613ef005b8SRafał Miłecki 	} while (0)
623ef005b8SRafał Miłecki 
63*78f0a64fSDmitry Osipenko #define bphy_info_once(drvr, fmt, ...)					\
64*78f0a64fSDmitry Osipenko 	wiphy_info_once((drvr)->wiphy, "%s: " fmt, __func__,		\
65*78f0a64fSDmitry Osipenko 			##__VA_ARGS__)
66*78f0a64fSDmitry Osipenko 
6705491d2cSKalle Valo #if defined(DEBUG) || defined(CONFIG_BRCM_TRACING)
68d79fe4cbSHans de Goede 
69d79fe4cbSHans de Goede /* For debug/tracing purposes treat info messages as errors */
70d79fe4cbSHans de Goede #define brcmf_info brcmf_err
71d79fe4cbSHans de Goede 
7205491d2cSKalle Valo __printf(3, 4)
7305491d2cSKalle Valo void __brcmf_dbg(u32 level, const char *func, const char *fmt, ...);
7405491d2cSKalle Valo #define brcmf_dbg(level, fmt, ...)				\
7505491d2cSKalle Valo do {								\
7605491d2cSKalle Valo 	__brcmf_dbg(BRCMF_##level##_VAL, __func__,		\
7705491d2cSKalle Valo 		    fmt, ##__VA_ARGS__);			\
7805491d2cSKalle Valo } while (0)
7905491d2cSKalle Valo #define BRCMF_DATA_ON()		(brcmf_msg_level & BRCMF_DATA_VAL)
8005491d2cSKalle Valo #define BRCMF_CTL_ON()		(brcmf_msg_level & BRCMF_CTL_VAL)
8105491d2cSKalle Valo #define BRCMF_HDRS_ON()		(brcmf_msg_level & BRCMF_HDRS_VAL)
8205491d2cSKalle Valo #define BRCMF_BYTES_ON()	(brcmf_msg_level & BRCMF_BYTES_VAL)
8305491d2cSKalle Valo #define BRCMF_GLOM_ON()		(brcmf_msg_level & BRCMF_GLOM_VAL)
8405491d2cSKalle Valo #define BRCMF_EVENT_ON()	(brcmf_msg_level & BRCMF_EVENT_VAL)
8505491d2cSKalle Valo #define BRCMF_FIL_ON()		(brcmf_msg_level & BRCMF_FIL_VAL)
8605491d2cSKalle Valo #define BRCMF_FWCON_ON()	(brcmf_msg_level & BRCMF_FWCON_VAL)
87efc2c1faSArend Van Spriel #define BRCMF_SCAN_ON()		(brcmf_msg_level & BRCMF_SCAN_VAL)
8805491d2cSKalle Valo 
8905491d2cSKalle Valo #else /* defined(DEBUG) || defined(CONFIG_BRCM_TRACING) */
9005491d2cSKalle Valo 
91d79fe4cbSHans de Goede #define brcmf_info(fmt, ...)						\
92d79fe4cbSHans de Goede 	do {								\
93d79fe4cbSHans de Goede 		pr_info("%s: " fmt, __func__, ##__VA_ARGS__);		\
94d79fe4cbSHans de Goede 	} while (0)
95d79fe4cbSHans de Goede 
9605491d2cSKalle Valo #define brcmf_dbg(level, fmt, ...) no_printk(fmt, ##__VA_ARGS__)
9705491d2cSKalle Valo 
9805491d2cSKalle Valo #define BRCMF_DATA_ON()		0
9905491d2cSKalle Valo #define BRCMF_CTL_ON()		0
10005491d2cSKalle Valo #define BRCMF_HDRS_ON()		0
10105491d2cSKalle Valo #define BRCMF_BYTES_ON()	0
10205491d2cSKalle Valo #define BRCMF_GLOM_ON()		0
10305491d2cSKalle Valo #define BRCMF_EVENT_ON()	0
10405491d2cSKalle Valo #define BRCMF_FIL_ON()		0
10505491d2cSKalle Valo #define BRCMF_FWCON_ON()	0
106efc2c1faSArend Van Spriel #define BRCMF_SCAN_ON()		0
10705491d2cSKalle Valo 
10805491d2cSKalle Valo #endif /* defined(DEBUG) || defined(CONFIG_BRCM_TRACING) */
10905491d2cSKalle Valo 
11005491d2cSKalle Valo #define brcmf_dbg_hex_dump(test, data, len, fmt, ...)			\
11105491d2cSKalle Valo do {									\
11205491d2cSKalle Valo 	trace_brcmf_hexdump((void *)data, len);				\
11305491d2cSKalle Valo 	if (test)							\
11405491d2cSKalle Valo 		brcmu_dbg_hex_dump(data, len, fmt, ##__VA_ARGS__);	\
11505491d2cSKalle Valo } while (0)
11605491d2cSKalle Valo 
11705491d2cSKalle Valo extern int brcmf_msg_level;
11805491d2cSKalle Valo 
11905491d2cSKalle Valo struct brcmf_pub;
12005491d2cSKalle Valo #ifdef DEBUG
12105491d2cSKalle Valo struct dentry *brcmf_debugfs_get_devdir(struct brcmf_pub *drvr);
122ea1b3bc6SGreg Kroah-Hartman void brcmf_debugfs_add_entry(struct brcmf_pub *drvr, const char *fn,
12305491d2cSKalle Valo 			     int (*read_fn)(struct seq_file *seq, void *data));
124f1ac3aa2SRafał Miłecki int brcmf_debug_create_memdump(struct brcmf_bus *bus, const void *data,
125f1ac3aa2SRafał Miłecki 			       size_t len);
12605491d2cSKalle Valo #else
brcmf_debugfs_get_devdir(struct brcmf_pub * drvr)127cb34212bSRafał Miłecki static inline struct dentry *brcmf_debugfs_get_devdir(struct brcmf_pub *drvr)
128cb34212bSRafał Miłecki {
129cb34212bSRafał Miłecki 	return ERR_PTR(-ENOENT);
130cb34212bSRafał Miłecki }
13105491d2cSKalle Valo static inline
brcmf_debugfs_add_entry(struct brcmf_pub * drvr,const char * fn,int (* read_fn)(struct seq_file * seq,void * data))132ea1b3bc6SGreg Kroah-Hartman void brcmf_debugfs_add_entry(struct brcmf_pub *drvr, const char *fn,
13305491d2cSKalle Valo 			     int (*read_fn)(struct seq_file *seq, void *data))
134ea1b3bc6SGreg Kroah-Hartman { }
135f1ac3aa2SRafał Miłecki static inline
brcmf_debug_create_memdump(struct brcmf_bus * bus,const void * data,size_t len)136f1ac3aa2SRafał Miłecki int brcmf_debug_create_memdump(struct brcmf_bus *bus, const void *data,
137f1ac3aa2SRafał Miłecki 			       size_t len)
138f1ac3aa2SRafał Miłecki {
139f1ac3aa2SRafał Miłecki 	return 0;
140f1ac3aa2SRafał Miłecki }
14105491d2cSKalle Valo #endif
14205491d2cSKalle Valo 
14305491d2cSKalle Valo #endif /* BRCMFMAC_DEBUG_H */
144