aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPatrick McHardy <kaber@trash.net>2007-03-14 19:39:25 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-04-26 01:25:43 -0400
commita3c5029cf7a96da3acdf6884a21581b5bef310c3 (patch)
treec599a8870e199562f4937193f2b3dc3d56a55145
parentc6a1e615d1ba942b9e783079d53f741e4a8e1c89 (diff)
[NETFILTER]: nfnetlink: use mutex instead of semaphore
Signed-off-by: Patrick McHardy <kaber@trash.net> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--include/linux/netfilter/nfnetlink.h13
-rw-r--r--include/net/netfilter/nf_conntrack_l3proto.h5
-rw-r--r--net/netfilter/nfnetlink.c35
3 files changed, 25 insertions, 28 deletions
diff --git a/include/linux/netfilter/nfnetlink.h b/include/linux/netfilter/nfnetlink.h
index 1e9c821f152d..6179648a014e 100644
--- a/include/linux/netfilter/nfnetlink.h
+++ b/include/linux/netfilter/nfnetlink.h
@@ -129,19 +129,6 @@ extern void __nfa_fill(struct sk_buff *skb, int attrtype,
129({ if (skb_tailroom(skb) < (int)NFA_SPACE(attrlen)) goto nfattr_failure; \ 129({ if (skb_tailroom(skb) < (int)NFA_SPACE(attrlen)) goto nfattr_failure; \
130 __nfa_fill(skb, attrtype, attrlen, data); }) 130 __nfa_fill(skb, attrtype, attrlen, data); })
131 131
132extern struct semaphore nfnl_sem;
133
134#define nfnl_shlock() down(&nfnl_sem)
135#define nfnl_shlock_nowait() down_trylock(&nfnl_sem)
136
137#define nfnl_shunlock() do { up(&nfnl_sem); \
138 if(nfnl && nfnl->sk_receive_queue.qlen) \
139 nfnl->sk_data_ready(nfnl, 0); \
140 } while(0)
141
142extern void nfnl_lock(void);
143extern void nfnl_unlock(void);
144
145extern int nfnetlink_subsys_register(struct nfnetlink_subsystem *n); 132extern int nfnetlink_subsys_register(struct nfnetlink_subsystem *n);
146extern int nfnetlink_subsys_unregister(struct nfnetlink_subsystem *n); 133extern int nfnetlink_subsys_unregister(struct nfnetlink_subsystem *n);
147 134
diff --git a/include/net/netfilter/nf_conntrack_l3proto.h b/include/net/netfilter/nf_conntrack_l3proto.h
index eb575cbd4c95..f32f714e5d92 100644
--- a/include/net/netfilter/nf_conntrack_l3proto.h
+++ b/include/net/netfilter/nf_conntrack_l3proto.h
@@ -90,10 +90,7 @@ extern struct nf_conntrack_l3proto *nf_ct_l3protos[AF_MAX];
90/* Protocol registration. */ 90/* Protocol registration. */
91extern int nf_conntrack_l3proto_register(struct nf_conntrack_l3proto *proto); 91extern int nf_conntrack_l3proto_register(struct nf_conntrack_l3proto *proto);
92extern void nf_conntrack_l3proto_unregister(struct nf_conntrack_l3proto *proto); 92extern void nf_conntrack_l3proto_unregister(struct nf_conntrack_l3proto *proto);
93 93extern struct nf_conntrack_l3proto *nf_ct_l3proto_find_get(u_int16_t l3proto);
94extern struct nf_conntrack_l3proto *
95nf_ct_l3proto_find_get(u_int16_t l3proto);
96
97extern void nf_ct_l3proto_put(struct nf_conntrack_l3proto *p); 94extern void nf_ct_l3proto_put(struct nf_conntrack_l3proto *p);
98 95
99/* Existing built-in protocols */ 96/* Existing built-in protocols */
diff --git a/net/netfilter/nfnetlink.c b/net/netfilter/nfnetlink.c
index bf23e489e4cd..7865a47c981e 100644
--- a/net/netfilter/nfnetlink.c
+++ b/net/netfilter/nfnetlink.c
@@ -28,6 +28,7 @@
28#include <asm/uaccess.h> 28#include <asm/uaccess.h>
29#include <asm/system.h> 29#include <asm/system.h>
30#include <net/sock.h> 30#include <net/sock.h>
31#include <net/netlink.h>
31#include <linux/init.h> 32#include <linux/init.h>
32#include <linux/spinlock.h> 33#include <linux/spinlock.h>
33 34
@@ -51,16 +52,28 @@ static char __initdata nfversion[] = "0.30";
51 52
52static struct sock *nfnl = NULL; 53static struct sock *nfnl = NULL;
53static struct nfnetlink_subsystem *subsys_table[NFNL_SUBSYS_COUNT]; 54static struct nfnetlink_subsystem *subsys_table[NFNL_SUBSYS_COUNT];
54DECLARE_MUTEX(nfnl_sem); 55static DEFINE_MUTEX(nfnl_mutex);
55 56
56void nfnl_lock(void) 57static void nfnl_lock(void)
57{ 58{
58 nfnl_shlock(); 59 mutex_lock(&nfnl_mutex);
59} 60}
60 61
61void nfnl_unlock(void) 62static int nfnl_trylock(void)
62{ 63{
63 nfnl_shunlock(); 64 return !mutex_trylock(&nfnl_mutex);
65}
66
67static void __nfnl_unlock(void)
68{
69 mutex_unlock(&nfnl_mutex);
70}
71
72static void nfnl_unlock(void)
73{
74 mutex_unlock(&nfnl_mutex);
75 if (nfnl->sk_receive_queue.qlen)
76 nfnl->sk_data_ready(nfnl, 0);
64} 77}
65 78
66int nfnetlink_subsys_register(struct nfnetlink_subsystem *n) 79int nfnetlink_subsys_register(struct nfnetlink_subsystem *n)
@@ -248,11 +261,11 @@ static int nfnetlink_rcv_msg(struct sk_buff *skb,
248 ss = nfnetlink_get_subsys(type); 261 ss = nfnetlink_get_subsys(type);
249 if (!ss) { 262 if (!ss) {
250#ifdef CONFIG_KMOD 263#ifdef CONFIG_KMOD
251 /* don't call nfnl_shunlock, since it would reenter 264 /* don't call nfnl_unlock, since it would reenter
252 * with further packet processing */ 265 * with further packet processing */
253 up(&nfnl_sem); 266 __nfnl_unlock();
254 request_module("nfnetlink-subsys-%d", NFNL_SUBSYS_ID(type)); 267 request_module("nfnetlink-subsys-%d", NFNL_SUBSYS_ID(type));
255 nfnl_shlock(); 268 nfnl_lock();
256 ss = nfnetlink_get_subsys(type); 269 ss = nfnetlink_get_subsys(type);
257 if (!ss) 270 if (!ss)
258#endif 271#endif
@@ -322,7 +335,7 @@ static void nfnetlink_rcv(struct sock *sk, int len)
322 do { 335 do {
323 struct sk_buff *skb; 336 struct sk_buff *skb;
324 337
325 if (nfnl_shlock_nowait()) 338 if (nfnl_trylock())
326 return; 339 return;
327 340
328 while ((skb = skb_dequeue(&sk->sk_receive_queue)) != NULL) { 341 while ((skb = skb_dequeue(&sk->sk_receive_queue)) != NULL) {
@@ -337,9 +350,9 @@ static void nfnetlink_rcv(struct sock *sk, int len)
337 kfree_skb(skb); 350 kfree_skb(skb);
338 } 351 }
339 352
340 /* don't call nfnl_shunlock, since it would reenter 353 /* don't call nfnl_unlock, since it would reenter
341 * with further packet processing */ 354 * with further packet processing */
342 up(&nfnl_sem); 355 __nfnl_unlock();
343 } while(nfnl && nfnl->sk_receive_queue.qlen); 356 } while(nfnl && nfnl->sk_receive_queue.qlen);
344} 357}
345 358