|
@@ -3369,6 +3369,7 @@ static int addrconf_notify(struct notifier_block *this, unsigned long event,
|
|
struct net_device *dev = netdev_notifier_info_to_dev(ptr);
|
|
struct net_device *dev = netdev_notifier_info_to_dev(ptr);
|
|
struct netdev_notifier_changeupper_info *info;
|
|
struct netdev_notifier_changeupper_info *info;
|
|
struct inet6_dev *idev = __in6_dev_get(dev);
|
|
struct inet6_dev *idev = __in6_dev_get(dev);
|
|
|
|
+ struct net *net = dev_net(dev);
|
|
int run_pending = 0;
|
|
int run_pending = 0;
|
|
int err;
|
|
int err;
|
|
|
|
|
|
@@ -3384,7 +3385,7 @@ static int addrconf_notify(struct notifier_block *this, unsigned long event,
|
|
case NETDEV_CHANGEMTU:
|
|
case NETDEV_CHANGEMTU:
|
|
/* if MTU under IPV6_MIN_MTU stop IPv6 on this interface. */
|
|
/* if MTU under IPV6_MIN_MTU stop IPv6 on this interface. */
|
|
if (dev->mtu < IPV6_MIN_MTU) {
|
|
if (dev->mtu < IPV6_MIN_MTU) {
|
|
- addrconf_ifdown(dev, 1);
|
|
|
|
|
|
+ addrconf_ifdown(dev, dev != net->loopback_dev);
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -3500,7 +3501,7 @@ static int addrconf_notify(struct notifier_block *this, unsigned long event,
|
|
* IPV6_MIN_MTU stop IPv6 on this interface.
|
|
* IPV6_MIN_MTU stop IPv6 on this interface.
|
|
*/
|
|
*/
|
|
if (dev->mtu < IPV6_MIN_MTU)
|
|
if (dev->mtu < IPV6_MIN_MTU)
|
|
- addrconf_ifdown(dev, 1);
|
|
|
|
|
|
+ addrconf_ifdown(dev, dev != net->loopback_dev);
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
|
|
|