net: vrf: Fix operation not supported when set vrf mac

Vrf device is not able to change mac address now because lack of
ndo_set_mac_address. Complete this in case some apps need to do
this.

Reported-by: Hui Wang <wanghui104@huawei.com>
Signed-off-by: Miaohe Lin <linmiaohe@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Miaohe Lin 2019-04-20 12:09:39 +08:00 committed by David S. Miller
parent 1c5c12ee30
commit 6819e3f6d8
1 changed files with 2 additions and 0 deletions

View File

@ -875,6 +875,7 @@ static const struct net_device_ops vrf_netdev_ops = {
.ndo_init = vrf_dev_init, .ndo_init = vrf_dev_init,
.ndo_uninit = vrf_dev_uninit, .ndo_uninit = vrf_dev_uninit,
.ndo_start_xmit = vrf_xmit, .ndo_start_xmit = vrf_xmit,
.ndo_set_mac_address = eth_mac_addr,
.ndo_get_stats64 = vrf_get_stats64, .ndo_get_stats64 = vrf_get_stats64,
.ndo_add_slave = vrf_add_slave, .ndo_add_slave = vrf_add_slave,
.ndo_del_slave = vrf_del_slave, .ndo_del_slave = vrf_del_slave,
@ -1274,6 +1275,7 @@ static void vrf_setup(struct net_device *dev)
/* default to no qdisc; user can add if desired */ /* default to no qdisc; user can add if desired */
dev->priv_flags |= IFF_NO_QUEUE; dev->priv_flags |= IFF_NO_QUEUE;
dev->priv_flags |= IFF_NO_RX_HANDLER; dev->priv_flags |= IFF_NO_RX_HANDLER;
dev->priv_flags |= IFF_LIVE_ADDR_CHANGE;
/* VRF devices do not care about MTU, but if the MTU is set /* VRF devices do not care about MTU, but if the MTU is set
* too low then the ipv4 and ipv6 protocols are disabled * too low then the ipv4 and ipv6 protocols are disabled