aboutsummaryrefslogtreecommitdiffstats
path: root/net/sched/sch_generic.c
diff options
context:
space:
mode:
authordavid decotigny <decot@googlers.com>2014-03-29 12:48:35 -0400
committerDavid S. Miller <davem@davemloft.net>2014-03-31 16:24:52 -0400
commit2d3b479df41a10e2f41f9259fcba775bd34de6e4 (patch)
tree517291066c35188a41b005e81904e69865643e76 /net/sched/sch_generic.c
parent9c76a114bbef10b4d44bd258006721dd896695dd (diff)
net-sysfs: expose number of carrier on/off changes
This allows to monitor carrier on/off transitions and detect link flapping issues: - new /sys/class/net/X/carrier_changes - new rtnetlink IFLA_CARRIER_CHANGES (getlink) Tested: - grep . /sys/class/net/*/carrier_changes + ip link set dev X down/up + plug/unplug cable - updated iproute2: prints IFLA_CARRIER_CHANGES - iproute2 20121211-2 (debian): unchanged behavior Signed-off-by: David Decotigny <decot@googlers.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/sched/sch_generic.c')
-rw-r--r--net/sched/sch_generic.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c
index e82e43b69c33..e1543b03e39d 100644
--- a/net/sched/sch_generic.c
+++ b/net/sched/sch_generic.c
@@ -310,6 +310,7 @@ void netif_carrier_on(struct net_device *dev)
310 if (test_and_clear_bit(__LINK_STATE_NOCARRIER, &dev->state)) { 310 if (test_and_clear_bit(__LINK_STATE_NOCARRIER, &dev->state)) {
311 if (dev->reg_state == NETREG_UNINITIALIZED) 311 if (dev->reg_state == NETREG_UNINITIALIZED)
312 return; 312 return;
313 atomic_inc(&dev->carrier_changes);
313 linkwatch_fire_event(dev); 314 linkwatch_fire_event(dev);
314 if (netif_running(dev)) 315 if (netif_running(dev))
315 __netdev_watchdog_up(dev); 316 __netdev_watchdog_up(dev);
@@ -328,6 +329,7 @@ void netif_carrier_off(struct net_device *dev)
328 if (!test_and_set_bit(__LINK_STATE_NOCARRIER, &dev->state)) { 329 if (!test_and_set_bit(__LINK_STATE_NOCARRIER, &dev->state)) {
329 if (dev->reg_state == NETREG_UNINITIALIZED) 330 if (dev->reg_state == NETREG_UNINITIALIZED)
330 return; 331 return;
332 atomic_inc(&dev->carrier_changes);
331 linkwatch_fire_event(dev); 333 linkwatch_fire_event(dev);
332 } 334 }
333} 335}