forked from mirrors/linux
		
	This config option enables network debugging checks. This patch adds DEBUG_NET_WARN_ON_ONCE(cond) Note that this is not a replacement for WARN_ON_ONCE(cond) as (cond) is not evaluated if CONFIG_DEBUG_NET is not set. Signed-off-by: Eric Dumazet <edumazet@google.com> Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			157 lines
		
	
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
	
		
			5.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
#ifndef _LINUX_NET_DEBUG_H
 | 
						|
#define _LINUX_NET_DEBUG_H
 | 
						|
 | 
						|
#include <linux/bug.h>
 | 
						|
#include <linux/kern_levels.h>
 | 
						|
 | 
						|
struct net_device;
 | 
						|
 | 
						|
__printf(3, 4) __cold
 | 
						|
void netdev_printk(const char *level, const struct net_device *dev,
 | 
						|
		   const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_emerg(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_alert(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_crit(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_err(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_warn(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_notice(const struct net_device *dev, const char *format, ...);
 | 
						|
__printf(2, 3) __cold
 | 
						|
void netdev_info(const struct net_device *dev, const char *format, ...);
 | 
						|
 | 
						|
#define netdev_level_once(level, dev, fmt, ...)			\
 | 
						|
do {								\
 | 
						|
	static bool __section(".data.once") __print_once;	\
 | 
						|
								\
 | 
						|
	if (!__print_once) {					\
 | 
						|
		__print_once = true;				\
 | 
						|
		netdev_printk(level, dev, fmt, ##__VA_ARGS__);	\
 | 
						|
	}							\
 | 
						|
} while (0)
 | 
						|
 | 
						|
#define netdev_emerg_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_EMERG, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_alert_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_ALERT, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_crit_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_CRIT, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_err_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_ERR, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_warn_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_WARNING, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_notice_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_NOTICE, dev, fmt, ##__VA_ARGS__)
 | 
						|
#define netdev_info_once(dev, fmt, ...) \
 | 
						|
	netdev_level_once(KERN_INFO, dev, fmt, ##__VA_ARGS__)
 | 
						|
 | 
						|
#if defined(CONFIG_DYNAMIC_DEBUG) || \
 | 
						|
	(defined(CONFIG_DYNAMIC_DEBUG_CORE) && defined(DYNAMIC_DEBUG_MODULE))
 | 
						|
#define netdev_dbg(__dev, format, args...)			\
 | 
						|
do {								\
 | 
						|
	dynamic_netdev_dbg(__dev, format, ##args);		\
 | 
						|
} while (0)
 | 
						|
#elif defined(DEBUG)
 | 
						|
#define netdev_dbg(__dev, format, args...)			\
 | 
						|
	netdev_printk(KERN_DEBUG, __dev, format, ##args)
 | 
						|
#else
 | 
						|
#define netdev_dbg(__dev, format, args...)			\
 | 
						|
({								\
 | 
						|
	if (0)							\
 | 
						|
		netdev_printk(KERN_DEBUG, __dev, format, ##args); \
 | 
						|
})
 | 
						|
#endif
 | 
						|
 | 
						|
#if defined(VERBOSE_DEBUG)
 | 
						|
#define netdev_vdbg	netdev_dbg
 | 
						|
#else
 | 
						|
 | 
						|
#define netdev_vdbg(dev, format, args...)			\
 | 
						|
({								\
 | 
						|
	if (0)							\
 | 
						|
		netdev_printk(KERN_DEBUG, dev, format, ##args);	\
 | 
						|
	0;							\
 | 
						|
})
 | 
						|
#endif
 | 
						|
 | 
						|
/* netif printk helpers, similar to netdev_printk */
 | 
						|
 | 
						|
#define netif_printk(priv, type, level, dev, fmt, args...)	\
 | 
						|
do {					  			\
 | 
						|
	if (netif_msg_##type(priv))				\
 | 
						|
		netdev_printk(level, (dev), fmt, ##args);	\
 | 
						|
} while (0)
 | 
						|
 | 
						|
#define netif_level(level, priv, type, dev, fmt, args...)	\
 | 
						|
do {								\
 | 
						|
	if (netif_msg_##type(priv))				\
 | 
						|
		netdev_##level(dev, fmt, ##args);		\
 | 
						|
} while (0)
 | 
						|
 | 
						|
#define netif_emerg(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(emerg, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_alert(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(alert, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_crit(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(crit, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_err(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(err, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_warn(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(warn, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_notice(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(notice, priv, type, dev, fmt, ##args)
 | 
						|
#define netif_info(priv, type, dev, fmt, args...)		\
 | 
						|
	netif_level(info, priv, type, dev, fmt, ##args)
 | 
						|
 | 
						|
#if defined(CONFIG_DYNAMIC_DEBUG) || \
 | 
						|
	(defined(CONFIG_DYNAMIC_DEBUG_CORE) && defined(DYNAMIC_DEBUG_MODULE))
 | 
						|
#define netif_dbg(priv, type, netdev, format, args...)		\
 | 
						|
do {								\
 | 
						|
	if (netif_msg_##type(priv))				\
 | 
						|
		dynamic_netdev_dbg(netdev, format, ##args);	\
 | 
						|
} while (0)
 | 
						|
#elif defined(DEBUG)
 | 
						|
#define netif_dbg(priv, type, dev, format, args...)		\
 | 
						|
	netif_printk(priv, type, KERN_DEBUG, dev, format, ##args)
 | 
						|
#else
 | 
						|
#define netif_dbg(priv, type, dev, format, args...)			\
 | 
						|
({									\
 | 
						|
	if (0)								\
 | 
						|
		netif_printk(priv, type, KERN_DEBUG, dev, format, ##args); \
 | 
						|
	0;								\
 | 
						|
})
 | 
						|
#endif
 | 
						|
 | 
						|
/* if @cond then downgrade to debug, else print at @level */
 | 
						|
#define netif_cond_dbg(priv, type, netdev, cond, level, fmt, args...)     \
 | 
						|
	do {                                                              \
 | 
						|
		if (cond)                                                 \
 | 
						|
			netif_dbg(priv, type, netdev, fmt, ##args);       \
 | 
						|
		else                                                      \
 | 
						|
			netif_ ## level(priv, type, netdev, fmt, ##args); \
 | 
						|
	} while (0)
 | 
						|
 | 
						|
#if defined(VERBOSE_DEBUG)
 | 
						|
#define netif_vdbg	netif_dbg
 | 
						|
#else
 | 
						|
#define netif_vdbg(priv, type, dev, format, args...)		\
 | 
						|
({								\
 | 
						|
	if (0)							\
 | 
						|
		netif_printk(priv, type, KERN_DEBUG, dev, format, ##args); \
 | 
						|
	0;							\
 | 
						|
})
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
#if defined(CONFIG_DEBUG_NET)
 | 
						|
#define DEBUG_NET_WARN_ON_ONCE(cond) (void)WARN_ON_ONCE(cond)
 | 
						|
#else
 | 
						|
#define DEBUG_NET_WARN_ON_ONCE(cond) BUILD_BUG_ON_INVALID(cond)
 | 
						|
#endif
 | 
						|
 | 
						|
#endif	/* _LINUX_NET_DEBUG_H */
 |