Message ID | 1480039506-29740-1-git-send-email-fgao@ikuai8.com |
---|---|
State | Accepted, archived |
Delegated to: | David Miller |
Headers | show |
On 2016年11月25日 10:05, fgao@48lvckh6395k16k5.yundunddos.com wrote: > From: Gao Feng <fgao@ikuai8.com> > > 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 <fgao@ikuai8.com> > --- > drivers/net/macvtap.c | 8 +++++++- > 1 file changed, 7 insertions(+), 1 deletion(-) > > diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c > index 070e329..bceca28 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, Acked-by: Jason Wang <jasowang@redhat.com>
From: fgao@ikuai8.com Date: Fri, 25 Nov 2016 10:05:06 +0800 > From: Gao Feng <fgao@ikuai8.com> > > 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 <fgao@ikuai8.com> Applied.
diff --git a/drivers/net/macvtap.c b/drivers/net/macvtap.c index 070e329..bceca28 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,