net: rtnl_configure_link: fix dev flags changes arg to __dev_notify_flags
commit 56a49d7048703f5ffdb84d3a0ee034108fba6850 upstream. This fix addresses https://bugzilla.kernel.org/show_bug.cgi?id=201071 Commit 5025f7f7d506 wrongly relied on __dev_change_flags to notify users of dev flag changes in the case when dev->rtnl_link_state = RTNL_LINK_INITIALIZED. Fix it by indicating flag changes explicitly to __dev_notify_flags. Fixes: 5025f7f7d506 ("rtnetlink: add rtnl_link_state check in rtnl_configure_link") Reported-By: Liam mcbirnie <liam.mcbirnie@boeing.com> Signed-off-by: Roopa Prabhu <roopa@cumulusnetworks.com> Signed-off-by: David S. Miller <davem@davemloft.net> Cc: Guenter Roeck <linux@roeck-us.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
baf1ece29a
commit
9c37f759a9
1 changed files with 1 additions and 1 deletions
|
@ -2105,7 +2105,7 @@ int rtnl_configure_link(struct net_device *dev, const struct ifinfomsg *ifm)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dev->rtnl_link_state == RTNL_LINK_INITIALIZED) {
|
if (dev->rtnl_link_state == RTNL_LINK_INITIALIZED) {
|
||||||
__dev_notify_flags(dev, old_flags, 0U);
|
__dev_notify_flags(dev, old_flags, (old_flags ^ dev->flags));
|
||||||
} else {
|
} else {
|
||||||
dev->rtnl_link_state = RTNL_LINK_INITIALIZED;
|
dev->rtnl_link_state = RTNL_LINK_INITIALIZED;
|
||||||
__dev_notify_flags(dev, old_flags, ~0U);
|
__dev_notify_flags(dev, old_flags, ~0U);
|
||||||
|
|
Loading…
Add table
Reference in a new issue