vrf: prevent adding upper devices
authorSabrina Dubroca <sd@queasysnail.net>
Tue, 26 Mar 2019 17:22:16 +0000 (18:22 +0100)
committerDavid S. Miller <davem@davemloft.net>
Thu, 28 Mar 2019 05:54:38 +0000 (22:54 -0700)
VRF devices don't work with upper devices. Currently, it's possible to
add a VRF device to a bridge or team, and to create macvlan, macsec, or
ipvlan devices on top of a VRF (bond and vlan are prevented respectively
by the lack of an ndo_set_mac_address op and the NETIF_F_VLAN_CHALLENGED
feature flag).

Fix this by setting the IFF_NO_RX_HANDLER flag (introduced in commit
f5426250a6ec ("net: introduce IFF_NO_RX_HANDLER")).

Cc: David Ahern <dsahern@gmail.com>
Fixes: 193125dbd8eb ("net: Introduce VRF device driver")
Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Acked-by: David Ahern <dsahern@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/vrf.c

index 7c1430ed02445b6e6f13c663b555ef550276c899..6d1a1abbed27e161f173f63ccb5aba5c6dca18ed 100644 (file)
@@ -1273,6 +1273,7 @@ static void vrf_setup(struct net_device *dev)
 
        /* default to no qdisc; user can add if desired */
        dev->priv_flags |= IFF_NO_QUEUE;
+       dev->priv_flags |= IFF_NO_RX_HANDLER;
 
        dev->min_mtu = 0;
        dev->max_mtu = 0;