|
@@ -197,8 +197,8 @@ int do_match(struct ipt_entry_match *m,
|
|
|
int *hotdrop)
|
|
|
{
|
|
|
/* Stop iteration if it doesn't match */
|
|
|
- if (!m->u.kernel.match->match(skb, in, out, m->data, offset,
|
|
|
- skb->nh.iph->ihl*4, hotdrop))
|
|
|
+ if (!m->u.kernel.match->match(skb, in, out, m->u.kernel.match, m->data,
|
|
|
+ offset, skb->nh.iph->ihl*4, hotdrop))
|
|
|
return 1;
|
|
|
else
|
|
|
return 0;
|
|
@@ -305,6 +305,7 @@ ipt_do_table(struct sk_buff **pskb,
|
|
|
verdict = t->u.kernel.target->target(pskb,
|
|
|
in, out,
|
|
|
hook,
|
|
|
+ t->u.kernel.target,
|
|
|
t->data,
|
|
|
userdata);
|
|
|
|
|
@@ -464,7 +465,7 @@ cleanup_match(struct ipt_entry_match *m, unsigned int *i)
|
|
|
return 1;
|
|
|
|
|
|
if (m->u.kernel.match->destroy)
|
|
|
- m->u.kernel.match->destroy(m->data,
|
|
|
+ m->u.kernel.match->destroy(m->u.kernel.match, m->data,
|
|
|
m->u.match_size - sizeof(*m));
|
|
|
module_put(m->u.kernel.match->me);
|
|
|
return 0;
|
|
@@ -517,7 +518,7 @@ check_match(struct ipt_entry_match *m,
|
|
|
goto err;
|
|
|
|
|
|
if (m->u.kernel.match->checkentry
|
|
|
- && !m->u.kernel.match->checkentry(name, ip, m->data,
|
|
|
+ && !m->u.kernel.match->checkentry(name, ip, match, m->data,
|
|
|
m->u.match_size - sizeof(*m),
|
|
|
hookmask)) {
|
|
|
duprintf("ip_tables: check failed for `%s'.\n",
|
|
@@ -578,7 +579,7 @@ check_entry(struct ipt_entry *e, const char *name, unsigned int size,
|
|
|
goto cleanup_matches;
|
|
|
}
|
|
|
} else if (t->u.kernel.target->checkentry
|
|
|
- && !t->u.kernel.target->checkentry(name, e, t->data,
|
|
|
+ && !t->u.kernel.target->checkentry(name, e, target, t->data,
|
|
|
t->u.target_size
|
|
|
- sizeof(*t),
|
|
|
e->comefrom)) {
|
|
@@ -652,7 +653,7 @@ cleanup_entry(struct ipt_entry *e, unsigned int *i)
|
|
|
IPT_MATCH_ITERATE(e, cleanup_match, NULL);
|
|
|
t = ipt_get_target(e);
|
|
|
if (t->u.kernel.target->destroy)
|
|
|
- t->u.kernel.target->destroy(t->data,
|
|
|
+ t->u.kernel.target->destroy(t->u.kernel.target, t->data,
|
|
|
t->u.target_size - sizeof(*t));
|
|
|
module_put(t->u.kernel.target->me);
|
|
|
return 0;
|