aboutsummaryrefslogtreecommitdiffstats
path: root/net/core
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 /net/core
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 'net/core')
-rw-r--r--net/core/dev.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/net/core/dev.c b/net/core/dev.c
index 239722af098d..81d61014fd9b 100644
--- a/net/core/dev.c
+++ b/net/core/dev.c
@@ -6950,12 +6950,14 @@ static int __netdev_printk(const char *level, const struct net_device *dev,
6950 if (dev && dev->dev.parent) { 6950 if (dev && dev->dev.parent) {
6951 r = dev_printk_emit(level[1] - '0', 6951 r = dev_printk_emit(level[1] - '0',
6952 dev->dev.parent, 6952 dev->dev.parent,
6953 "%s %s %s: %pV", 6953 "%s %s %s%s: %pV",
6954 dev_driver_string(dev->dev.parent), 6954 dev_driver_string(dev->dev.parent),
6955 dev_name(dev->dev.parent), 6955 dev_name(dev->dev.parent),
6956 netdev_name(dev), vaf); 6956 netdev_name(dev), netdev_reg_state(dev),
6957 vaf);
6957 } else if (dev) { 6958 } else if (dev) {
6958 r = printk("%s%s: %pV", level, netdev_name(dev), vaf); 6959 r = printk("%s%s%s: %pV", level, netdev_name(dev),
6960 netdev_reg_state(dev), vaf);
6959 } else { 6961 } else {
6960 r = printk("%s(NULL net_device): %pV", level, vaf); 6962 r = printk("%s(NULL net_device): %pV", level, vaf);
6961 } 6963 }