diff options
| author | David S. Miller <davem@davemloft.net> | 2014-07-20 23:39:16 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2014-07-20 23:39:16 -0400 |
| commit | 4ec6837804e4a0e096930f9d989952cb081eae2f (patch) | |
| tree | 92c83d2cbb4ff1a24b21295853f3c5008d1d0158 /include | |
| parent | 3e403a77779faf046862d91c36ef79fb4b12be9a (diff) | |
| parent | ccc7f4968a18b980994e622006b84e0195754390 (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.h | 22 |
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 | ||
| 3384 | static inline const char *netdev_name(const struct net_device *dev) | 3384 | static 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 | ||
| 3391 | static 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) |
| 3392 | int netdev_printk(const char *level, const struct net_device *dev, | 3407 | int 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 | ||
