[NET]: Make device event notification network namespace safe
Every user of the network device notifiers is either a protocol stack or a pseudo device. If a protocol stack that does not have support for multiple network namespaces receives an event for a device that is not in the initial network namespace it quite possibly can get confused and do the wrong thing. To avoid problems until all of the protocol stacks are converted this patch modifies all netdev event handlers to ignore events on devices that are not in the initial network namespace. As the rest of the code is made network namespace aware these checks can be removed. Signed-off-by: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:

کامیت شده توسط
David S. Miller

والد
e730c15519
کامیت
e9dc865340
@@ -612,6 +612,9 @@ static int clip_device_event(struct notifier_block *this, unsigned long event,
|
||||
{
|
||||
struct net_device *dev = arg;
|
||||
|
||||
if (dev->nd_net != &init_net)
|
||||
return NOTIFY_DONE;
|
||||
|
||||
if (event == NETDEV_UNREGISTER) {
|
||||
neigh_ifdown(&clip_tbl, dev);
|
||||
return NOTIFY_DONE;
|
||||
|
@@ -956,6 +956,10 @@ static int mpoa_event_listener(struct notifier_block *mpoa_notifier, unsigned lo
|
||||
struct lec_priv *priv;
|
||||
|
||||
dev = (struct net_device *)dev_ptr;
|
||||
|
||||
if (dev->nd_net != &init_net)
|
||||
return NOTIFY_DONE;
|
||||
|
||||
if (dev->name == NULL || strncmp(dev->name, "lec", 3))
|
||||
return NOTIFY_DONE; /* we are only interested in lec:s */
|
||||
|
||||
|
مرجع در شماره جدید
Block a user