 3fae027316
			
		
	
	
	3fae027316
	
	
	
		
			
			It can be very useful to have all debug messages available when debugging, but hard to correlate between different sources, so add a trace event for all mac80211 debug messages. Signed-off-by: Johannes Berg <johannes.berg@intel.com>
		
			
				
	
	
		
			170 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			170 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __MAC80211_DEBUG_H
 | |
| #define __MAC80211_DEBUG_H
 | |
| #include <net/cfg80211.h>
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_IBSS_DEBUG
 | |
| #define MAC80211_IBSS_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_IBSS_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_PS_DEBUG
 | |
| #define MAC80211_PS_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_PS_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_HT_DEBUG
 | |
| #define MAC80211_HT_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_HT_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MPL_DEBUG
 | |
| #define MAC80211_MPL_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_MPL_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MPATH_DEBUG
 | |
| #define MAC80211_MPATH_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_MPATH_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MHWMP_DEBUG
 | |
| #define MAC80211_MHWMP_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_MHWMP_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MESH_SYNC_DEBUG
 | |
| #define MAC80211_MESH_SYNC_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_MESH_SYNC_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_TDLS_DEBUG
 | |
| #define MAC80211_TDLS_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_TDLS_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_STA_DEBUG
 | |
| #define MAC80211_STA_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_STA_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MLME_DEBUG
 | |
| #define MAC80211_MLME_DEBUG 1
 | |
| #else
 | |
| #define MAC80211_MLME_DEBUG 0
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_MAC80211_MESSAGE_TRACING
 | |
| void __sdata_info(const char *fmt, ...) __printf(1, 2);
 | |
| void __sdata_dbg(bool print, const char *fmt, ...) __printf(2, 3);
 | |
| void __sdata_err(const char *fmt, ...) __printf(1, 2);
 | |
| void __wiphy_dbg(struct wiphy *wiphy, bool print, const char *fmt, ...)
 | |
| 	__printf(3, 4);
 | |
| 
 | |
| #define _sdata_info(sdata, fmt, ...)					\
 | |
| 	__sdata_info("%s: " fmt, (sdata)->name, ##__VA_ARGS__)
 | |
| #define _sdata_dbg(print, sdata, fmt, ...)				\
 | |
| 	__sdata_dbg(print, "%s: " fmt, (sdata)->name, ##__VA_ARGS__)
 | |
| #define _sdata_err(sdata, fmt, ...)					\
 | |
| 	__sdata_err("%s: " fmt, (sdata)->name, ##__VA_ARGS__)
 | |
| #define _wiphy_dbg(print, wiphy, fmt, ...)				\
 | |
| 	__wiphy_dbg(wiphy, print, fmt, ##__VA_ARGS__)
 | |
| #else
 | |
| #define _sdata_info(sdata, fmt, ...)					\
 | |
| do {									\
 | |
| 	pr_info("%s: " fmt,						\
 | |
| 		(sdata)->name, ##__VA_ARGS__);				\
 | |
| } while (0)
 | |
| 
 | |
| #define _sdata_dbg(print, sdata, fmt, ...)				\
 | |
| do {									\
 | |
| 	if (print)							\
 | |
| 		pr_debug("%s: " fmt,					\
 | |
| 			 (sdata)->name, ##__VA_ARGS__);			\
 | |
| } while (0)
 | |
| 
 | |
| #define _sdata_err(sdata, fmt, ...)					\
 | |
| do {									\
 | |
| 	pr_err("%s: " fmt,						\
 | |
| 	       (sdata)->name, ##__VA_ARGS__);				\
 | |
| } while (0)
 | |
| 
 | |
| #define _wiphy_dbg(print, wiphy, fmt, ...)				\
 | |
| do {									\
 | |
| 	if (print)							\
 | |
| 		wiphy_dbg((wiphy), fmt, ##__VA_ARGS__);			\
 | |
| } while (0)
 | |
| #endif
 | |
| 
 | |
| #define sdata_info(sdata, fmt, ...)					\
 | |
| 	_sdata_info(sdata, fmt, ##__VA_ARGS__)
 | |
| #define sdata_err(sdata, fmt, ...)					\
 | |
| 	_sdata_err(sdata, fmt, ##__VA_ARGS__)
 | |
| #define sdata_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(1, sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ht_dbg(sdata, fmt, ...)						\
 | |
| 	_sdata_dbg(MAC80211_HT_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ht_dbg_ratelimited(sdata, fmt, ...)				\
 | |
| 	_sdata_dbg(MAC80211_HT_DEBUG && net_ratelimit(),		\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ibss_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_IBSS_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ps_dbg(sdata, fmt, ...)						\
 | |
| 	_sdata_dbg(MAC80211_PS_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ps_dbg_hw(hw, fmt, ...)						\
 | |
| 	_wiphy_dbg(MAC80211_PS_DEBUG,					\
 | |
| 		   (hw)->wiphy, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define ps_dbg_ratelimited(sdata, fmt, ...)				\
 | |
| 	_sdata_dbg(MAC80211_PS_DEBUG && net_ratelimit(),		\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define mpl_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_MPL_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define mpath_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_MPATH_DEBUG,				\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define mhwmp_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_MHWMP_DEBUG,				\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define msync_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_MESH_SYNC_DEBUG,				\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define tdls_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_TDLS_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define sta_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_STA_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define mlme_dbg(sdata, fmt, ...)					\
 | |
| 	_sdata_dbg(MAC80211_MLME_DEBUG,					\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #define mlme_dbg_ratelimited(sdata, fmt, ...)				\
 | |
| 	_sdata_dbg(MAC80211_MLME_DEBUG && net_ratelimit(),		\
 | |
| 		   sdata, fmt, ##__VA_ARGS__)
 | |
| 
 | |
| #endif /* __MAC80211_DEBUG_H */
 |