Commit 4b478248 authored by Patrick McHardy's avatar Patrick McHardy Committed by David S. Miller

[NETFILTER]: ip_tables: reformat compat code

The compat code has some very odd formating, clean it up before porting
it to ip6_tables.
Signed-off-by: default avatarPatrick McHardy <kaber@trash.net>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ac8e27fd
...@@ -600,8 +600,8 @@ check_entry(struct ipt_entry *e, const char *name) ...@@ -600,8 +600,8 @@ check_entry(struct ipt_entry *e, const char *name)
} }
static inline int check_match(struct ipt_entry_match *m, const char *name, static inline int check_match(struct ipt_entry_match *m, const char *name,
const struct ipt_ip *ip, unsigned int hookmask, const struct ipt_ip *ip,
unsigned int *i) unsigned int hookmask, unsigned int *i)
{ {
struct xt_match *match; struct xt_match *match;
int ret; int ret;
...@@ -663,8 +663,8 @@ static inline int check_target(struct ipt_entry *e, const char *name) ...@@ -663,8 +663,8 @@ static inline int check_target(struct ipt_entry *e, const char *name)
name, e->comefrom, e->ip.proto, name, e->comefrom, e->ip.proto,
e->ip.invflags & IPT_INV_PROTO); e->ip.invflags & IPT_INV_PROTO);
if (!ret && t->u.kernel.target->checkentry if (!ret && t->u.kernel.target->checkentry
&& !t->u.kernel.target->checkentry(name, e, target, && !t->u.kernel.target->checkentry(name, e, target, t->data,
t->data, e->comefrom)) { e->comefrom)) {
duprintf("ip_tables: check failed for `%s'.\n", duprintf("ip_tables: check failed for `%s'.\n",
t->u.kernel.target->name); t->u.kernel.target->name);
ret = -EINVAL; ret = -EINVAL;
...@@ -1020,7 +1020,7 @@ struct compat_delta { ...@@ -1020,7 +1020,7 @@ struct compat_delta {
short delta; short delta;
}; };
static struct compat_delta *compat_offsets = NULL; static struct compat_delta *compat_offsets;
static int compat_add_offset(unsigned int offset, short delta) static int compat_add_offset(unsigned int offset, short delta)
{ {
...@@ -1046,7 +1046,7 @@ static void compat_flush_offsets(void) ...@@ -1046,7 +1046,7 @@ static void compat_flush_offsets(void)
struct compat_delta *tmp, *next; struct compat_delta *tmp, *next;
if (compat_offsets) { if (compat_offsets) {
for(tmp = compat_offsets; tmp; tmp = next) { for (tmp = compat_offsets; tmp; tmp = next) {
next = tmp->next; next = tmp->next;
kfree(tmp); kfree(tmp);
} }
...@@ -1059,7 +1059,7 @@ static short compat_calc_jump(unsigned int offset) ...@@ -1059,7 +1059,7 @@ static short compat_calc_jump(unsigned int offset)
struct compat_delta *tmp; struct compat_delta *tmp;
short delta; short delta;
for(tmp = compat_offsets, delta = 0; tmp; tmp = tmp->next) for (tmp = compat_offsets, delta = 0; tmp; tmp = tmp->next)
if (tmp->offset < offset) if (tmp->offset < offset)
delta += tmp->delta; delta += tmp->delta;
return delta; return delta;
...@@ -1084,7 +1084,7 @@ static int compat_standard_to_user(void __user *dst, void *src) ...@@ -1084,7 +1084,7 @@ static int compat_standard_to_user(void __user *dst, void *src)
} }
static inline int static inline int
compat_calc_match(struct ipt_entry_match *m, int * size) compat_calc_match(struct ipt_entry_match *m, int *size)
{ {
*size += xt_compat_match_offset(m->u.kernel.match); *size += xt_compat_match_offset(m->u.kernel.match);
return 0; return 0;
...@@ -1109,11 +1109,11 @@ static int compat_calc_entry(struct ipt_entry *e, ...@@ -1109,11 +1109,11 @@ static int compat_calc_entry(struct ipt_entry *e,
return ret; return ret;
for (i = 0; i < NF_INET_NUMHOOKS; i++) { for (i = 0; i < NF_INET_NUMHOOKS; i++) {
if (info->hook_entry[i] && (e < (struct ipt_entry *) if (info->hook_entry[i] &&
(base + info->hook_entry[i]))) (e < (struct ipt_entry *)(base + info->hook_entry[i])))
newinfo->hook_entry[i] -= off; newinfo->hook_entry[i] -= off;
if (info->underflow[i] && (e < (struct ipt_entry *) if (info->underflow[i] &&
(base + info->underflow[i]))) (e < (struct ipt_entry *)(base + info->underflow[i])))
newinfo->underflow[i] -= off; newinfo->underflow[i] -= off;
} }
return 0; return 0;
...@@ -1132,7 +1132,8 @@ static int compat_table_info(const struct xt_table_info *info, ...@@ -1132,7 +1132,8 @@ static int compat_table_info(const struct xt_table_info *info,
newinfo->initial_entries = 0; newinfo->initial_entries = 0;
loc_cpu_entry = info->entries[raw_smp_processor_id()]; loc_cpu_entry = info->entries[raw_smp_processor_id()];
return IPT_ENTRY_ITERATE(loc_cpu_entry, info->size, return IPT_ENTRY_ITERATE(loc_cpu_entry, info->size,
compat_calc_entry, info, loc_cpu_entry, newinfo); compat_calc_entry, info, loc_cpu_entry,
newinfo);
} }
#endif #endif
...@@ -1289,7 +1290,8 @@ __do_replace(const char *name, unsigned int valid_hooks, ...@@ -1289,7 +1290,8 @@ __do_replace(const char *name, unsigned int valid_hooks,
get_counters(oldinfo, counters); get_counters(oldinfo, counters);
/* Decrease module usage counts and free resource */ /* Decrease module usage counts and free resource */
loc_cpu_old_entry = oldinfo->entries[raw_smp_processor_id()]; loc_cpu_old_entry = oldinfo->entries[raw_smp_processor_id()];
IPT_ENTRY_ITERATE(loc_cpu_old_entry, oldinfo->size, cleanup_entry,NULL); IPT_ENTRY_ITERATE(loc_cpu_old_entry, oldinfo->size, cleanup_entry,
NULL);
xt_free_table_info(oldinfo); xt_free_table_info(oldinfo);
if (copy_to_user(counters_ptr, counters, if (copy_to_user(counters_ptr, counters,
sizeof(struct xt_counters) * num_counters) != 0) sizeof(struct xt_counters) * num_counters) != 0)
...@@ -1346,9 +1348,8 @@ do_replace(void __user *user, unsigned int len) ...@@ -1346,9 +1348,8 @@ do_replace(void __user *user, unsigned int len)
duprintf("ip_tables: Translated table\n"); duprintf("ip_tables: Translated table\n");
ret = __do_replace(tmp.name, tmp.valid_hooks, ret = __do_replace(tmp.name, tmp.valid_hooks, newinfo,
newinfo, tmp.num_counters, tmp.num_counters, tmp.counters);
tmp.counters);
if (ret) if (ret)
goto free_newinfo_untrans; goto free_newinfo_untrans;
return 0; return 0;
...@@ -1653,15 +1654,18 @@ check_compat_entry_size_and_hooks(struct ipt_entry *e, ...@@ -1653,15 +1654,18 @@ check_compat_entry_size_and_hooks(struct ipt_entry *e,
return ret; return ret;
} }
static inline int compat_copy_match_from_user(struct ipt_entry_match *m, static inline int
void **dstptr, compat_uint_t *size, const char *name, compat_copy_match_from_user(struct ipt_entry_match *m,
const struct ipt_ip *ip, unsigned int hookmask) void **dstptr, compat_uint_t *size,
const char *name, const struct ipt_ip *ip,
unsigned int hookmask)
{ {
xt_compat_match_from_user(m, dstptr, size); xt_compat_match_from_user(m, dstptr, size);
return 0; return 0;
} }
static int compat_copy_entry_from_user(struct ipt_entry *e, void **dstptr, static int
compat_copy_entry_from_user(struct ipt_entry *e, void **dstptr,
unsigned int *size, const char *name, unsigned int *size, const char *name,
struct xt_table_info *newinfo, unsigned char *base) struct xt_table_info *newinfo, unsigned char *base)
{ {
...@@ -1874,21 +1878,21 @@ compat_do_replace(void __user *user, unsigned int len) ...@@ -1874,21 +1878,21 @@ compat_do_replace(void __user *user, unsigned int len)
ret = translate_compat_table(tmp.name, tmp.valid_hooks, ret = translate_compat_table(tmp.name, tmp.valid_hooks,
&newinfo, &loc_cpu_entry, tmp.size, &newinfo, &loc_cpu_entry, tmp.size,
tmp.num_entries, tmp.hook_entry, tmp.underflow); tmp.num_entries, tmp.hook_entry,
tmp.underflow);
if (ret != 0) if (ret != 0)
goto free_newinfo; goto free_newinfo;
duprintf("compat_do_replace: Translated table\n"); duprintf("compat_do_replace: Translated table\n");
ret = __do_replace(tmp.name, tmp.valid_hooks, ret = __do_replace(tmp.name, tmp.valid_hooks, newinfo,
newinfo, tmp.num_counters, tmp.num_counters, compat_ptr(tmp.counters));
compat_ptr(tmp.counters));
if (ret) if (ret)
goto free_newinfo_untrans; goto free_newinfo_untrans;
return 0; return 0;
free_newinfo_untrans: free_newinfo_untrans:
IPT_ENTRY_ITERATE(loc_cpu_entry, newinfo->size, cleanup_entry,NULL); IPT_ENTRY_ITERATE(loc_cpu_entry, newinfo->size, cleanup_entry, NULL);
free_newinfo: free_newinfo:
xt_free_table_info(newinfo); xt_free_table_info(newinfo);
return ret; return ret;
...@@ -1920,15 +1924,15 @@ compat_do_ipt_set_ctl(struct sock *sk, int cmd, void __user *user, ...@@ -1920,15 +1924,15 @@ compat_do_ipt_set_ctl(struct sock *sk, int cmd, void __user *user,
return ret; return ret;
} }
struct compat_ipt_get_entries struct compat_ipt_get_entries {
{
char name[IPT_TABLE_MAXNAMELEN]; char name[IPT_TABLE_MAXNAMELEN];
compat_uint_t size; compat_uint_t size;
struct compat_ipt_entry entrytable[0]; struct compat_ipt_entry entrytable[0];
}; };
static int compat_copy_entries_to_user(unsigned int total_size, static int
struct xt_table *table, void __user *userptr) compat_copy_entries_to_user(unsigned int total_size, struct xt_table *table,
void __user *userptr)
{ {
struct xt_counters *counters; struct xt_counters *counters;
struct xt_table_info *private = table->private; struct xt_table_info *private = table->private;
...@@ -1964,7 +1968,6 @@ compat_get_entries(struct compat_ipt_get_entries __user *uptr, int *len) ...@@ -1964,7 +1968,6 @@ compat_get_entries(struct compat_ipt_get_entries __user *uptr, int *len)
struct compat_ipt_get_entries get; struct compat_ipt_get_entries get;
struct xt_table *t; struct xt_table *t;
if (*len < sizeof(get)) { if (*len < sizeof(get)) {
duprintf("compat_get_entries: %u < %u\n", duprintf("compat_get_entries: %u < %u\n",
*len, (unsigned int)sizeof(get)); *len, (unsigned int)sizeof(get));
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment