diff options
author | stephen hemminger <shemminger@vyatta.com> | 2010-07-22 20:45:04 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-07-25 06:04:20 +0200 |
commit | 3b87956ea645fb4de7e59c7d0aa94de04be72615 (patch) | |
tree | 0dde04e6dfad7cd76afbb31eff72a8f08a574a9c /net/core/sock.c | |
parent | Merge branch 'wimax-2.6.35.y' of git://git.kernel.org/pub/scm/linux/kernel/gi... (diff) | |
download | linux-3b87956ea645fb4de7e59c7d0aa94de04be72615.tar.xz linux-3b87956ea645fb4de7e59c7d0aa94de04be72615.zip |
net sched: fix race in mirred device removal
This fixes hang when target device of mirred packet classifier
action is removed.
If a mirror or redirection action is configured to cause packets
to go to another device, the classifier holds a ref count, but was assuming
the adminstrator cleaned up all redirections before removing. The fix
is to add a notifier and cleanup during unregister.
The new list is implicitly protected by RTNL mutex because
it is held during filter add/delete as well as notifier.
Signed-off-by: Stephen Hemminger <shemminger@vyatta.com>
Acked-by: Jamal Hadi Salim <hadi@cyberus.ca>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/sock.c')
0 files changed, 0 insertions, 0 deletions