summaryrefslogtreecommitdiffstats
path: root/drivers/net/macvlan.c
diff options
context:
space:
mode:
authorTravis Brown <travisb@arista.com>2018-07-10 02:35:01 +0200
committerDavid S. Miller <davem@davemloft.net>2018-07-12 08:07:22 +0200
commit80fd2d6ca5461b2752744df2e6e387cc65e7b86c (patch)
tree55ec1959f1ca3a72c9c6b4c5d8c536034f3a1482 /drivers/net/macvlan.c
parentMerge branch 'tipc-make-link-protocol-more-resilient' (diff)
downloadlinux-80fd2d6ca5461b2752744df2e6e387cc65e7b86c.tar.xz
linux-80fd2d6ca5461b2752744df2e6e387cc65e7b86c.zip
macvlan: Change status when lower device goes down
Today macvlan ignores the notification when a lower device goes administratively down, preventing the lack of connectivity from bubbling up. Processing NETDEV_DOWN results in a macvlan state of LOWERLAYERDOWN with NO-CARRIER which should be easy to interpret in userspace. 2: lower: <BROADCAST,MULTICAST> mtu 1500 qdisc mq state DOWN mode DEFAULT group default qlen 1000 3: macvlan@lower: <NO-CARRIER,BROADCAST,MULTICAST,UP,M-DOWN> mtu 1500 qdisc noqueue state LOWERLAYERDOWN mode DEFAULT group default qlen 1000 Signed-off-by: Suresh Krishnan <skrishnan@arista.com> Signed-off-by: Travis Brown <travisb@arista.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/macvlan.c')
-rw-r--r--drivers/net/macvlan.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/net/macvlan.c b/drivers/net/macvlan.c
index 401e1d1ce1ec..cfda146f3b3b 100644
--- a/drivers/net/macvlan.c
+++ b/drivers/net/macvlan.c
@@ -1641,6 +1641,7 @@ static int macvlan_device_event(struct notifier_block *unused,
switch (event) {
case NETDEV_UP:
+ case NETDEV_DOWN:
case NETDEV_CHANGE:
list_for_each_entry(vlan, &port->vlans, list)
netif_stacked_transfer_operstate(vlan->lowerdev,