提交 9e19bb6d 编写于 作者: I Ingo Molnar 提交者: David S. Miller

[NETFILTER] x_table.c: sem2mutex

Semaphore to mutex conversion.

The conversion was generated via scripts, and the result was validated
automatically via a script as well.
Signed-off-by: NIngo Molnar <mingo@elte.hu>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 cef2685e
...@@ -21,10 +21,12 @@ ...@@ -21,10 +21,12 @@
#include <linux/seq_file.h> #include <linux/seq_file.h>
#include <linux/string.h> #include <linux/string.h>
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include <linux/mutex.h>
#include <linux/netfilter/x_tables.h> #include <linux/netfilter/x_tables.h>
#include <linux/netfilter_arp.h> #include <linux/netfilter_arp.h>
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
MODULE_AUTHOR("Harald Welte <laforge@netfilter.org>"); MODULE_AUTHOR("Harald Welte <laforge@netfilter.org>");
MODULE_DESCRIPTION("[ip,ip6,arp]_tables backend module"); MODULE_DESCRIPTION("[ip,ip6,arp]_tables backend module");
...@@ -32,7 +34,7 @@ MODULE_DESCRIPTION("[ip,ip6,arp]_tables backend module"); ...@@ -32,7 +34,7 @@ MODULE_DESCRIPTION("[ip,ip6,arp]_tables backend module");
#define SMP_ALIGN(x) (((x) + SMP_CACHE_BYTES-1) & ~(SMP_CACHE_BYTES-1)) #define SMP_ALIGN(x) (((x) + SMP_CACHE_BYTES-1) & ~(SMP_CACHE_BYTES-1))
struct xt_af { struct xt_af {
struct semaphore mutex; struct mutex mutex;
struct list_head match; struct list_head match;
struct list_head target; struct list_head target;
struct list_head tables; struct list_head tables;
...@@ -64,11 +66,11 @@ xt_register_target(struct xt_target *target) ...@@ -64,11 +66,11 @@ xt_register_target(struct xt_target *target)
{ {
int ret, af = target->family; int ret, af = target->family;
ret = down_interruptible(&xt[af].mutex); ret = mutex_lock_interruptible(&xt[af].mutex);
if (ret != 0) if (ret != 0)
return ret; return ret;
list_add(&target->list, &xt[af].target); list_add(&target->list, &xt[af].target);
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return ret; return ret;
} }
EXPORT_SYMBOL(xt_register_target); EXPORT_SYMBOL(xt_register_target);
...@@ -78,9 +80,9 @@ xt_unregister_target(struct xt_target *target) ...@@ -78,9 +80,9 @@ xt_unregister_target(struct xt_target *target)
{ {
int af = target->family; int af = target->family;
down(&xt[af].mutex); mutex_lock(&xt[af].mutex);
LIST_DELETE(&xt[af].target, target); LIST_DELETE(&xt[af].target, target);
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
} }
EXPORT_SYMBOL(xt_unregister_target); EXPORT_SYMBOL(xt_unregister_target);
...@@ -89,12 +91,12 @@ xt_register_match(struct xt_match *match) ...@@ -89,12 +91,12 @@ xt_register_match(struct xt_match *match)
{ {
int ret, af = match->family; int ret, af = match->family;
ret = down_interruptible(&xt[af].mutex); ret = mutex_lock_interruptible(&xt[af].mutex);
if (ret != 0) if (ret != 0)
return ret; return ret;
list_add(&match->list, &xt[af].match); list_add(&match->list, &xt[af].match);
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return ret; return ret;
} }
...@@ -105,9 +107,9 @@ xt_unregister_match(struct xt_match *match) ...@@ -105,9 +107,9 @@ xt_unregister_match(struct xt_match *match)
{ {
int af = match->family; int af = match->family;
down(&xt[af].mutex); mutex_lock(&xt[af].mutex);
LIST_DELETE(&xt[af].match, match); LIST_DELETE(&xt[af].match, match);
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
} }
EXPORT_SYMBOL(xt_unregister_match); EXPORT_SYMBOL(xt_unregister_match);
...@@ -124,21 +126,21 @@ struct xt_match *xt_find_match(int af, const char *name, u8 revision) ...@@ -124,21 +126,21 @@ struct xt_match *xt_find_match(int af, const char *name, u8 revision)
struct xt_match *m; struct xt_match *m;
int err = 0; int err = 0;
if (down_interruptible(&xt[af].mutex) != 0) if (mutex_lock_interruptible(&xt[af].mutex) != 0)
return ERR_PTR(-EINTR); return ERR_PTR(-EINTR);
list_for_each_entry(m, &xt[af].match, list) { list_for_each_entry(m, &xt[af].match, list) {
if (strcmp(m->name, name) == 0) { if (strcmp(m->name, name) == 0) {
if (m->revision == revision) { if (m->revision == revision) {
if (try_module_get(m->me)) { if (try_module_get(m->me)) {
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return m; return m;
} }
} else } else
err = -EPROTOTYPE; /* Found something. */ err = -EPROTOTYPE; /* Found something. */
} }
} }
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return ERR_PTR(err); return ERR_PTR(err);
} }
EXPORT_SYMBOL(xt_find_match); EXPORT_SYMBOL(xt_find_match);
...@@ -149,21 +151,21 @@ struct xt_target *xt_find_target(int af, const char *name, u8 revision) ...@@ -149,21 +151,21 @@ struct xt_target *xt_find_target(int af, const char *name, u8 revision)
struct xt_target *t; struct xt_target *t;
int err = 0; int err = 0;
if (down_interruptible(&xt[af].mutex) != 0) if (mutex_lock_interruptible(&xt[af].mutex) != 0)
return ERR_PTR(-EINTR); return ERR_PTR(-EINTR);
list_for_each_entry(t, &xt[af].target, list) { list_for_each_entry(t, &xt[af].target, list) {
if (strcmp(t->name, name) == 0) { if (strcmp(t->name, name) == 0) {
if (t->revision == revision) { if (t->revision == revision) {
if (try_module_get(t->me)) { if (try_module_get(t->me)) {
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return t; return t;
} }
} else } else
err = -EPROTOTYPE; /* Found something. */ err = -EPROTOTYPE; /* Found something. */
} }
} }
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return ERR_PTR(err); return ERR_PTR(err);
} }
EXPORT_SYMBOL(xt_find_target); EXPORT_SYMBOL(xt_find_target);
...@@ -218,7 +220,7 @@ int xt_find_revision(int af, const char *name, u8 revision, int target, ...@@ -218,7 +220,7 @@ int xt_find_revision(int af, const char *name, u8 revision, int target,
{ {
int have_rev, best = -1; int have_rev, best = -1;
if (down_interruptible(&xt[af].mutex) != 0) { if (mutex_lock_interruptible(&xt[af].mutex) != 0) {
*err = -EINTR; *err = -EINTR;
return 1; return 1;
} }
...@@ -226,7 +228,7 @@ int xt_find_revision(int af, const char *name, u8 revision, int target, ...@@ -226,7 +228,7 @@ int xt_find_revision(int af, const char *name, u8 revision, int target,
have_rev = target_revfn(af, name, revision, &best); have_rev = target_revfn(af, name, revision, &best);
else else
have_rev = match_revfn(af, name, revision, &best); have_rev = match_revfn(af, name, revision, &best);
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
/* Nothing at all? Return 0 to try loading module. */ /* Nothing at all? Return 0 to try loading module. */
if (best == -1) { if (best == -1) {
...@@ -352,20 +354,20 @@ struct xt_table *xt_find_table_lock(int af, const char *name) ...@@ -352,20 +354,20 @@ struct xt_table *xt_find_table_lock(int af, const char *name)
{ {
struct xt_table *t; struct xt_table *t;
if (down_interruptible(&xt[af].mutex) != 0) if (mutex_lock_interruptible(&xt[af].mutex) != 0)
return ERR_PTR(-EINTR); return ERR_PTR(-EINTR);
list_for_each_entry(t, &xt[af].tables, list) list_for_each_entry(t, &xt[af].tables, list)
if (strcmp(t->name, name) == 0 && try_module_get(t->me)) if (strcmp(t->name, name) == 0 && try_module_get(t->me))
return t; return t;
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
return NULL; return NULL;
} }
EXPORT_SYMBOL_GPL(xt_find_table_lock); EXPORT_SYMBOL_GPL(xt_find_table_lock);
void xt_table_unlock(struct xt_table *table) void xt_table_unlock(struct xt_table *table)
{ {
up(&xt[table->af].mutex); mutex_unlock(&xt[table->af].mutex);
} }
EXPORT_SYMBOL_GPL(xt_table_unlock); EXPORT_SYMBOL_GPL(xt_table_unlock);
...@@ -405,7 +407,7 @@ int xt_register_table(struct xt_table *table, ...@@ -405,7 +407,7 @@ int xt_register_table(struct xt_table *table,
int ret; int ret;
struct xt_table_info *private; struct xt_table_info *private;
ret = down_interruptible(&xt[table->af].mutex); ret = mutex_lock_interruptible(&xt[table->af].mutex);
if (ret != 0) if (ret != 0)
return ret; return ret;
...@@ -431,7 +433,7 @@ int xt_register_table(struct xt_table *table, ...@@ -431,7 +433,7 @@ int xt_register_table(struct xt_table *table,
ret = 0; ret = 0;
unlock: unlock:
up(&xt[table->af].mutex); mutex_unlock(&xt[table->af].mutex);
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(xt_register_table); EXPORT_SYMBOL_GPL(xt_register_table);
...@@ -440,10 +442,10 @@ void *xt_unregister_table(struct xt_table *table) ...@@ -440,10 +442,10 @@ void *xt_unregister_table(struct xt_table *table)
{ {
struct xt_table_info *private; struct xt_table_info *private;
down(&xt[table->af].mutex); mutex_lock(&xt[table->af].mutex);
private = table->private; private = table->private;
LIST_DELETE(&xt[table->af].tables, table); LIST_DELETE(&xt[table->af].tables, table);
up(&xt[table->af].mutex); mutex_unlock(&xt[table->af].mutex);
return private; return private;
} }
...@@ -507,7 +509,7 @@ static void *xt_tgt_seq_start(struct seq_file *seq, loff_t *pos) ...@@ -507,7 +509,7 @@ static void *xt_tgt_seq_start(struct seq_file *seq, loff_t *pos)
if (!list) if (!list)
return NULL; return NULL;
if (down_interruptible(&xt[af].mutex) != 0) if (mutex_lock_interruptible(&xt[af].mutex) != 0)
return NULL; return NULL;
return xt_get_idx(list, seq, *pos); return xt_get_idx(list, seq, *pos);
...@@ -536,7 +538,7 @@ static void xt_tgt_seq_stop(struct seq_file *seq, void *v) ...@@ -536,7 +538,7 @@ static void xt_tgt_seq_stop(struct seq_file *seq, void *v)
struct proc_dir_entry *pde = seq->private; struct proc_dir_entry *pde = seq->private;
u_int16_t af = (unsigned long)pde->data & 0xffff; u_int16_t af = (unsigned long)pde->data & 0xffff;
up(&xt[af].mutex); mutex_unlock(&xt[af].mutex);
} }
static int xt_name_seq_show(struct seq_file *seq, void *v) static int xt_name_seq_show(struct seq_file *seq, void *v)
...@@ -668,7 +670,7 @@ static int __init xt_init(void) ...@@ -668,7 +670,7 @@ static int __init xt_init(void)
return -ENOMEM; return -ENOMEM;
for (i = 0; i < NPROTO; i++) { for (i = 0; i < NPROTO; i++) {
init_MUTEX(&xt[i].mutex); mutex_init(&xt[i].mutex);
INIT_LIST_HEAD(&xt[i].target); INIT_LIST_HEAD(&xt[i].target);
INIT_LIST_HEAD(&xt[i].match); INIT_LIST_HEAD(&xt[i].match);
INIT_LIST_HEAD(&xt[i].tables); INIT_LIST_HEAD(&xt[i].tables);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册