aboutsummaryrefslogtreecommitdiffstats
path: root/net/netfilter/nf_queue.c
diff options
context:
space:
mode:
authorYasuyuki Kozakai <yasuyuki.kozakai@toshiba.co.jp>2007-07-07 22:40:08 -0700
committerDavid S. Miller <davem@sunset.davemloft.net>2007-07-10 22:18:21 -0700
commitce7663d84a87bb4e1743f62950bf7dceed723a13 (patch)
tree3c1b16e33913199da3181b92ed7dc0fbb6e0aa64 /net/netfilter/nf_queue.c
parent0d53778e81ac7af266dac8a20cc328328c327112 (diff)
downloadkernel_samsung_smdk4412-ce7663d84a87bb4e1743f62950bf7dceed723a13.zip
kernel_samsung_smdk4412-ce7663d84a87bb4e1743f62950bf7dceed723a13.tar.gz
kernel_samsung_smdk4412-ce7663d84a87bb4e1743f62950bf7dceed723a13.tar.bz2
[NETFILTER]: nfnetlink_queue: don't unregister handler of other subsystem
The queue handlers registered by ip[6]_queue.ko at initialization should not be unregistered according to requests from userland program using nfnetlink_queue. If we allow that, there is no way to register the handlers of built-in ip[6]_queue again. Signed-off-by: Yasuyuki Kozakai <yasuyuki.kozakai@toshiba.co.jp> Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/netfilter/nf_queue.c')
-rw-r--r--net/netfilter/nf_queue.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/net/netfilter/nf_queue.c b/net/netfilter/nf_queue.c
index b1f2ace..f402894 100644
--- a/net/netfilter/nf_queue.c
+++ b/net/netfilter/nf_queue.c
@@ -44,12 +44,17 @@ int nf_register_queue_handler(int pf, struct nf_queue_handler *qh)
EXPORT_SYMBOL(nf_register_queue_handler);
/* The caller must flush their queue before this */
-int nf_unregister_queue_handler(int pf)
+int nf_unregister_queue_handler(int pf, struct nf_queue_handler *qh)
{
if (pf >= NPROTO)
return -EINVAL;
write_lock_bh(&queue_handler_lock);
+ if (queue_handler[pf] != qh) {
+ write_unlock_bh(&queue_handler_lock);
+ return -EINVAL;
+ }
+
queue_handler[pf] = NULL;
write_unlock_bh(&queue_handler_lock);