aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2014-07-20 23:39:16 -0400
committerDavid S. Miller <davem@davemloft.net>2014-07-20 23:39:16 -0400
commit4ec6837804e4a0e096930f9d989952cb081eae2f (patch)
tree92c83d2cbb4ff1a24b21295853f3c5008d1d0158 /include
parent3e403a77779faf046862d91c36ef79fb4b12be9a (diff)
parentccc7f4968a18b980994e622006b84e0195754390 (diff)
Merge branch 'netdev_print'
Veaceslav Falico says: ==================== net: print net_device name/state more often Currently we use net_device->name only if it's the NETREG_REGISTERED reg_state, otherwise we return "(unregistered device)". However, we always populate net_device->name on creation, so it's always available to us for use. The only caveat is that we might have a name like "eth%d", in which case we cannot use it as it might change in the future. Also, the net_device might not be NETREG_UNREGISTERED when the function is called (_UNINITIALIZED, _UNREGISTERING, _RELEASED, _DUMMY), so it's misleading. So, a better way would be to always return the dev->name in netdev_name(), unless it's in the form of "eth%d" or it's empty, then return "unnamed net_device". This way we'll always return the name in NETREG_REGISTERED reg_state, and also return it in other states, when possible. Also, to be more verbose on non-NETREG_REGISTERED states, add a function netdev_reg_state(), which returns a string describing the state, and use it in netdev_printk()-related functions. If the dev is in NETREG_REGISTERED state then a void string is regurned and, thus, nothing changes. After these two patches we'll have the same behaviour in the usual cases, and more verbose in non-standardad/buggy ones. v2->v3: Correct the string for _UNINITIALIZED and warn on a bad reg_state, per Joe Perches's comments. v1->v2: As Tom Gundersen suggested, there might be a case when we have an empty string as a name for a device, so account this also and return "unnamed device" for that case too. ==================== Signed-off-by: Veaceslav Falico <vfalico@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include')
-rw-r--r--include/linux/netdevice.h22
1 files changed, 19 insertions, 3 deletions
diff --git a/include/linux/netdevice.h b/include/linux/netdevice.h
index 15ed750458ad..8e8fb3ed574b 100644
--- a/include/linux/netdevice.h
+++ b/include/linux/netdevice.h
@@ -3383,11 +3383,26 @@ extern struct pernet_operations __net_initdata loopback_net_ops;
3383 3383
3384static inline const char *netdev_name(const struct net_device *dev) 3384static inline const char *netdev_name(const struct net_device *dev)
3385{ 3385{
3386 if (dev->reg_state != NETREG_REGISTERED) 3386 if (!dev->name[0] || strchr(dev->name, '%'))
3387 return "(unregistered net_device)"; 3387 return "(unnamed net_device)";
3388 return dev->name; 3388 return dev->name;
3389} 3389}
3390 3390
3391static inline const char *netdev_reg_state(const struct net_device *dev)
3392{
3393 switch (dev->reg_state) {
3394 case NETREG_UNINITIALIZED: return " (uninitialized)";
3395 case NETREG_REGISTERED: return "";
3396 case NETREG_UNREGISTERING: return " (unregistering)";
3397 case NETREG_UNREGISTERED: return " (unregistered)";
3398 case NETREG_RELEASED: return " (released)";
3399 case NETREG_DUMMY: return " (dummy)";
3400 }
3401
3402 WARN_ONCE(1, "%s: unknown reg_state %d\n", dev->name, dev->reg_state);
3403 return " (unknown)";
3404}
3405
3391__printf(3, 4) 3406__printf(3, 4)
3392int netdev_printk(const char *level, const struct net_device *dev, 3407int netdev_printk(const char *level, const struct net_device *dev,
3393 const char *format, ...); 3408 const char *format, ...);
@@ -3444,7 +3459,8 @@ do { \
3444 * file/line information and a backtrace. 3459 * file/line information and a backtrace.
3445 */ 3460 */
3446#define netdev_WARN(dev, format, args...) \ 3461#define netdev_WARN(dev, format, args...) \
3447 WARN(1, "netdevice: %s\n" format, netdev_name(dev), ##args) 3462 WARN(1, "netdevice: %s%s\n" format, netdev_name(dev), \
3463 netdev_reg_state(dev), ##args)
3448 3464
3449/* netif printk helpers, similar to netdev_printk */ 3465/* netif printk helpers, similar to netdev_printk */
3450 3466