From: Gao Feng Date: Fri, 25 Nov 2016 02:05:06 +0000 (+0800) Subject: driver: macvtap: Unregister netdev rx_handler if macvtap_newlink fails X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=e824265d632629c3d2583d86b8a816e886a5136c;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git driver: macvtap: Unregister netdev rx_handler if macvtap_newlink fails The macvtap_newlink registers the netdev rx_handler firstly, but it does not unregister the handler if macvlan_common_newlink failed. Signed-off-by: Gao Feng Acked-by: Jason Wang Signed-off-by: David S. Miller --- diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index 070e3290aa6e..bceca2875771 100644 --- a/drivers/net/macvtap.c +++ b/drivers/net/macvtap.c @@ -491,7 +491,13 @@ static int macvtap_newlink(struct net *src_net, /* Don't put anything that may fail after macvlan_common_newlink * because we can't undo what it does. */ - return macvlan_common_newlink(src_net, dev, tb, data); + err = macvlan_common_newlink(src_net, dev, tb, data); + if (err) { + netdev_rx_handler_unregister(dev); + return err; + } + + return 0; } static void macvtap_dellink(struct net_device *dev,