netns: filter out uevent not belonging to init_net
This patch will filter out the uevent not related to the init_net. Without this patch if a network device is created in a network namespace with the same name as one network device belonging to the initial network namespace (eg. eth0), when the network namespace will die and the network device will be destroyed, an event will be sent and catched by the udevd daemon. That will result to have the real network device to be shutdown because the udevd/uevent are not namespace aware. Signed-off-by: Daniel Lezcano <dlezcano@fr.ibm.com> Acked-by: "Eric W. Biederman" <ebiederm@xmission.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
cb13fc209f
commit
09bb52175b
1 changed files with 3 additions and 0 deletions
|
@ -427,6 +427,9 @@ static int netdev_uevent(struct device *d, struct kobj_uevent_env *env)
|
||||||
struct net_device *dev = to_net_dev(d);
|
struct net_device *dev = to_net_dev(d);
|
||||||
int retval;
|
int retval;
|
||||||
|
|
||||||
|
if (!net_eq(dev_net(dev), &init_net))
|
||||||
|
return 0;
|
||||||
|
|
||||||
/* pass interface to uevent. */
|
/* pass interface to uevent. */
|
||||||
retval = add_uevent_var(env, "INTERFACE=%s", dev->name);
|
retval = add_uevent_var(env, "INTERFACE=%s", dev->name);
|
||||||
if (retval)
|
if (retval)
|
||||||
|
|
Loading…
Reference in a new issue