diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2007-09-12 07:02:17 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-10-10 19:49:09 -0400 |
commit | e9dc86534051b78e41e5b746cccc291b57a3a311 (patch) | |
tree | 1cd4a1dde4c51b6311749428a22cc8a8f5436825 /net/ipv4/ipmr.c | |
parent | e730c15519d09ea528b4d2f1103681fa5937c0e6 (diff) |
[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>
Diffstat (limited to 'net/ipv4/ipmr.c')
-rw-r--r-- | net/ipv4/ipmr.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c index 35683e1a42e8..036598835c63 100644 --- a/net/ipv4/ipmr.c +++ b/net/ipv4/ipmr.c | |||
@@ -1083,13 +1083,18 @@ int ipmr_ioctl(struct sock *sk, int cmd, void __user *arg) | |||
1083 | 1083 | ||
1084 | static int ipmr_device_event(struct notifier_block *this, unsigned long event, void *ptr) | 1084 | static int ipmr_device_event(struct notifier_block *this, unsigned long event, void *ptr) |
1085 | { | 1085 | { |
1086 | struct net_device *dev = ptr; | ||
1086 | struct vif_device *v; | 1087 | struct vif_device *v; |
1087 | int ct; | 1088 | int ct; |
1089 | |||
1090 | if (dev->nd_net != &init_net) | ||
1091 | return NOTIFY_DONE; | ||
1092 | |||
1088 | if (event != NETDEV_UNREGISTER) | 1093 | if (event != NETDEV_UNREGISTER) |
1089 | return NOTIFY_DONE; | 1094 | return NOTIFY_DONE; |
1090 | v=&vif_table[0]; | 1095 | v=&vif_table[0]; |
1091 | for (ct=0;ct<maxvif;ct++,v++) { | 1096 | for (ct=0;ct<maxvif;ct++,v++) { |
1092 | if (v->dev==ptr) | 1097 | if (v->dev==dev) |
1093 | vif_delete(ct); | 1098 | vif_delete(ct); |
1094 | } | 1099 | } |
1095 | return NOTIFY_DONE; | 1100 | return NOTIFY_DONE; |