[NETFILTER]: nf_conntrack_expect: function naming unification

Currently there is a wild mix of nf_conntrack_expect_, nf_ct_exp_,
expect_, exp_, ...

Consistently use nf_ct_ as prefix for exported functions.

Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Patrick McHardy 2007-07-07 22:30:49 -07:00 committed by David S. Miller
parent 53aba5979e
commit 6823645d60
25 changed files with 251 additions and 259 deletions

View File

@ -84,7 +84,7 @@ print_tuple(struct seq_file *s, const struct nf_conntrack_tuple *tuple,
struct nf_conntrack_l4proto *proto); struct nf_conntrack_l4proto *proto);
extern struct hlist_head *nf_conntrack_hash; extern struct hlist_head *nf_conntrack_hash;
extern struct list_head nf_conntrack_expect_list; extern struct list_head nf_ct_expect_list;
extern rwlock_t nf_conntrack_lock ; extern rwlock_t nf_conntrack_lock ;
extern struct hlist_head unconfirmed; extern struct hlist_head unconfirmed;

View File

@ -49,15 +49,15 @@ static inline void nf_conntrack_event(enum ip_conntrack_events event,
atomic_notifier_call_chain(&nf_conntrack_chain, event, ct); atomic_notifier_call_chain(&nf_conntrack_chain, event, ct);
} }
extern struct atomic_notifier_head nf_conntrack_expect_chain; extern struct atomic_notifier_head nf_ct_expect_chain;
extern int nf_conntrack_expect_register_notifier(struct notifier_block *nb); extern int nf_ct_expect_register_notifier(struct notifier_block *nb);
extern int nf_conntrack_expect_unregister_notifier(struct notifier_block *nb); extern int nf_ct_expect_unregister_notifier(struct notifier_block *nb);
static inline void static inline void
nf_conntrack_expect_event(enum ip_conntrack_expect_events event, nf_ct_expect_event(enum ip_conntrack_expect_events event,
struct nf_conntrack_expect *exp) struct nf_conntrack_expect *exp)
{ {
atomic_notifier_call_chain(&nf_conntrack_expect_chain, event, exp); atomic_notifier_call_chain(&nf_ct_expect_chain, event, exp);
} }
#else /* CONFIG_NF_CONNTRACK_EVENTS */ #else /* CONFIG_NF_CONNTRACK_EVENTS */
@ -67,9 +67,8 @@ static inline void nf_conntrack_event_cache(enum ip_conntrack_events event,
static inline void nf_conntrack_event(enum ip_conntrack_events event, static inline void nf_conntrack_event(enum ip_conntrack_events event,
struct nf_conn *ct) {} struct nf_conn *ct) {}
static inline void nf_ct_deliver_cached_events(const struct nf_conn *ct) {} static inline void nf_ct_deliver_cached_events(const struct nf_conn *ct) {}
static inline void static inline void nf_ct_expect_event(enum ip_conntrack_expect_events event,
nf_conntrack_expect_event(enum ip_conntrack_expect_events event, struct nf_conntrack_expect *exp) {}
struct nf_conntrack_expect *exp) {}
static inline void nf_ct_event_cache_flush(void) {} static inline void nf_ct_event_cache_flush(void) {}
#endif /* CONFIG_NF_CONNTRACK_EVENTS */ #endif /* CONFIG_NF_CONNTRACK_EVENTS */

View File

@ -6,8 +6,8 @@
#define _NF_CONNTRACK_EXPECT_H #define _NF_CONNTRACK_EXPECT_H
#include <net/netfilter/nf_conntrack.h> #include <net/netfilter/nf_conntrack.h>
extern struct list_head nf_conntrack_expect_list; extern struct list_head nf_ct_expect_list;
extern struct kmem_cache *nf_conntrack_expect_cachep; extern struct kmem_cache *nf_ct_expect_cachep;
extern const struct file_operations exp_file_ops; extern const struct file_operations exp_file_ops;
struct nf_conntrack_expect struct nf_conntrack_expect
@ -54,27 +54,27 @@ struct nf_conntrack_expect
struct nf_conntrack_expect * struct nf_conntrack_expect *
__nf_conntrack_expect_find(const struct nf_conntrack_tuple *tuple); __nf_ct_expect_find(const struct nf_conntrack_tuple *tuple);
struct nf_conntrack_expect * struct nf_conntrack_expect *
nf_conntrack_expect_find_get(const struct nf_conntrack_tuple *tuple); nf_ct_expect_find_get(const struct nf_conntrack_tuple *tuple);
struct nf_conntrack_expect * struct nf_conntrack_expect *
find_expectation(const struct nf_conntrack_tuple *tuple); nf_ct_find_expectation(const struct nf_conntrack_tuple *tuple);
void nf_ct_unlink_expect(struct nf_conntrack_expect *exp); void nf_ct_unlink_expect(struct nf_conntrack_expect *exp);
void nf_ct_remove_expectations(struct nf_conn *ct); void nf_ct_remove_expectations(struct nf_conn *ct);
void nf_conntrack_unexpect_related(struct nf_conntrack_expect *exp); void nf_ct_unexpect_related(struct nf_conntrack_expect *exp);
/* Allocate space for an expectation: this is mandatory before calling /* Allocate space for an expectation: this is mandatory before calling
nf_conntrack_expect_related. You will have to call put afterwards. */ nf_ct_expect_related. You will have to call put afterwards. */
struct nf_conntrack_expect *nf_conntrack_expect_alloc(struct nf_conn *me); struct nf_conntrack_expect *nf_ct_expect_alloc(struct nf_conn *me);
void nf_conntrack_expect_init(struct nf_conntrack_expect *, int, void nf_ct_expect_init(struct nf_conntrack_expect *, int,
union nf_conntrack_address *, union nf_conntrack_address *,
union nf_conntrack_address *, union nf_conntrack_address *,
u_int8_t, __be16 *, __be16 *); u_int8_t, __be16 *, __be16 *);
void nf_conntrack_expect_put(struct nf_conntrack_expect *exp); void nf_ct_expect_put(struct nf_conntrack_expect *exp);
int nf_conntrack_expect_related(struct nf_conntrack_expect *expect); int nf_ct_expect_related(struct nf_conntrack_expect *expect);
#endif /*_NF_CONNTRACK_EXPECT_H*/ #endif /*_NF_CONNTRACK_EXPECT_H*/

View File

@ -209,7 +209,7 @@ static const struct file_operations ct_file_ops = {
/* expects */ /* expects */
static void *exp_seq_start(struct seq_file *s, loff_t *pos) static void *exp_seq_start(struct seq_file *s, loff_t *pos)
{ {
struct list_head *e = &nf_conntrack_expect_list; struct list_head *e = &nf_ct_expect_list;
loff_t i; loff_t i;
/* strange seq_file api calls stop even if we fail, /* strange seq_file api calls stop even if we fail,
@ -221,7 +221,7 @@ static void *exp_seq_start(struct seq_file *s, loff_t *pos)
for (i = 0; i <= *pos; i++) { for (i = 0; i <= *pos; i++) {
e = e->next; e = e->next;
if (e == &nf_conntrack_expect_list) if (e == &nf_ct_expect_list)
return NULL; return NULL;
} }
return e; return e;
@ -234,7 +234,7 @@ static void *exp_seq_next(struct seq_file *s, void *v, loff_t *pos)
++*pos; ++*pos;
e = e->next; e = e->next;
if (e == &nf_conntrack_expect_list) if (e == &nf_ct_expect_list)
return NULL; return NULL;
return e; return e;

View File

@ -45,7 +45,7 @@ static unsigned int help(struct sk_buff **pskb,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) { for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) {
exp->tuple.dst.u.tcp.port = htons(port); exp->tuple.dst.u.tcp.port = htons(port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -57,7 +57,7 @@ static unsigned int help(struct sk_buff **pskb,
matchoff, matchlen, matchoff, matchlen,
buffer, strlen(buffer)); buffer, strlen(buffer));
if (ret != NF_ACCEPT) if (ret != NF_ACCEPT)
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return ret; return ret;
} }

View File

@ -131,7 +131,7 @@ static unsigned int nf_nat_ftp(struct sk_buff **pskb,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) { for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) {
exp->tuple.dst.u.tcp.port = htons(port); exp->tuple.dst.u.tcp.port = htons(port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -139,7 +139,7 @@ static unsigned int nf_nat_ftp(struct sk_buff **pskb,
return NF_DROP; return NF_DROP;
if (!mangle[type](pskb, newip, port, matchoff, matchlen, ct, ctinfo)) { if (!mangle[type](pskb, newip, port, matchoff, matchlen, ct, ctinfo)) {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return NF_DROP; return NF_DROP;
} }
return NF_ACCEPT; return NF_ACCEPT;

View File

@ -237,12 +237,12 @@ static int nat_rtp_rtcp(struct sk_buff **pskb, struct nf_conn *ct,
for (nated_port = ntohs(rtp_exp->tuple.dst.u.udp.port); for (nated_port = ntohs(rtp_exp->tuple.dst.u.udp.port);
nated_port != 0; nated_port += 2) { nated_port != 0; nated_port += 2) {
rtp_exp->tuple.dst.u.udp.port = htons(nated_port); rtp_exp->tuple.dst.u.udp.port = htons(nated_port);
if (nf_conntrack_expect_related(rtp_exp) == 0) { if (nf_ct_expect_related(rtp_exp) == 0) {
rtcp_exp->tuple.dst.u.udp.port = rtcp_exp->tuple.dst.u.udp.port =
htons(nated_port + 1); htons(nated_port + 1);
if (nf_conntrack_expect_related(rtcp_exp) == 0) if (nf_ct_expect_related(rtcp_exp) == 0)
break; break;
nf_conntrack_unexpect_related(rtp_exp); nf_ct_unexpect_related(rtp_exp);
} }
} }
@ -261,8 +261,8 @@ static int nat_rtp_rtcp(struct sk_buff **pskb, struct nf_conn *ct,
info->rtp_port[i][dir] = rtp_port; info->rtp_port[i][dir] = rtp_port;
info->rtp_port[i][!dir] = htons(nated_port); info->rtp_port[i][!dir] = htons(nated_port);
} else { } else {
nf_conntrack_unexpect_related(rtp_exp); nf_ct_unexpect_related(rtp_exp);
nf_conntrack_unexpect_related(rtcp_exp); nf_ct_unexpect_related(rtcp_exp);
return -1; return -1;
} }
@ -299,7 +299,7 @@ static int nat_t120(struct sk_buff **pskb, struct nf_conn *ct,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (; nated_port != 0; nated_port++) { for (; nated_port != 0; nated_port++) {
exp->tuple.dst.u.tcp.port = htons(nated_port); exp->tuple.dst.u.tcp.port = htons(nated_port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -313,7 +313,7 @@ static int nat_t120(struct sk_buff **pskb, struct nf_conn *ct,
if (set_h245_addr(pskb, data, dataoff, taddr, if (set_h245_addr(pskb, data, dataoff, taddr,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
htons(nated_port)) < 0) { htons(nated_port)) < 0) {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return -1; return -1;
} }
@ -347,7 +347,7 @@ static int nat_h245(struct sk_buff **pskb, struct nf_conn *ct,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (; nated_port != 0; nated_port++) { for (; nated_port != 0; nated_port++) {
exp->tuple.dst.u.tcp.port = htons(nated_port); exp->tuple.dst.u.tcp.port = htons(nated_port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -365,7 +365,7 @@ static int nat_h245(struct sk_buff **pskb, struct nf_conn *ct,
info->sig_port[dir] = port; info->sig_port[dir] = port;
info->sig_port[!dir] = htons(nated_port); info->sig_port[!dir] = htons(nated_port);
} else { } else {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return -1; return -1;
} }
@ -433,7 +433,7 @@ static int nat_q931(struct sk_buff **pskb, struct nf_conn *ct,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (; nated_port != 0; nated_port++) { for (; nated_port != 0; nated_port++) {
exp->tuple.dst.u.tcp.port = htons(nated_port); exp->tuple.dst.u.tcp.port = htons(nated_port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -460,7 +460,7 @@ static int nat_q931(struct sk_buff **pskb, struct nf_conn *ct,
info->sig_port[!dir]); info->sig_port[!dir]);
} }
} else { } else {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return -1; return -1;
} }
@ -517,7 +517,7 @@ static int nat_callforwarding(struct sk_buff **pskb, struct nf_conn *ct,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (nated_port = ntohs(port); nated_port != 0; nated_port++) { for (nated_port = ntohs(port); nated_port != 0; nated_port++) {
exp->tuple.dst.u.tcp.port = htons(nated_port); exp->tuple.dst.u.tcp.port = htons(nated_port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -531,7 +531,7 @@ static int nat_callforwarding(struct sk_buff **pskb, struct nf_conn *ct,
if (!set_h225_addr(pskb, data, dataoff, taddr, if (!set_h225_addr(pskb, data, dataoff, taddr,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
htons(nated_port)) == 0) { htons(nated_port)) == 0) {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return -1; return -1;
} }

View File

@ -55,7 +55,7 @@ static unsigned int help(struct sk_buff **pskb,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) { for (port = ntohs(exp->saved_proto.tcp.port); port != 0; port++) {
exp->tuple.dst.u.tcp.port = htons(port); exp->tuple.dst.u.tcp.port = htons(port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -71,7 +71,7 @@ static unsigned int help(struct sk_buff **pskb,
matchoff, matchlen, buffer, matchoff, matchlen, buffer,
strlen(buffer)); strlen(buffer));
if (ret != NF_ACCEPT) if (ret != NF_ACCEPT)
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return ret; return ret;
} }

View File

@ -81,10 +81,10 @@ static void pptp_nat_expected(struct nf_conn *ct,
DEBUGP("trying to unexpect other dir: "); DEBUGP("trying to unexpect other dir: ");
NF_CT_DUMP_TUPLE(&t); NF_CT_DUMP_TUPLE(&t);
other_exp = nf_conntrack_expect_find_get(&t); other_exp = nf_ct_expect_find_get(&t);
if (other_exp) { if (other_exp) {
nf_conntrack_unexpect_related(other_exp); nf_ct_unexpect_related(other_exp);
nf_conntrack_expect_put(other_exp); nf_ct_expect_put(other_exp);
DEBUGP("success\n"); DEBUGP("success\n");
} else { } else {
DEBUGP("not found!\n"); DEBUGP("not found!\n");

View File

@ -278,7 +278,7 @@ static unsigned int ip_nat_sdp(struct sk_buff **pskb,
/* Try to get same port: if not, try to change it. */ /* Try to get same port: if not, try to change it. */
for (port = ntohs(exp->saved_proto.udp.port); port != 0; port++) { for (port = ntohs(exp->saved_proto.udp.port); port != 0; port++) {
exp->tuple.dst.u.udp.port = htons(port); exp->tuple.dst.u.udp.port = htons(port);
if (nf_conntrack_expect_related(exp) == 0) if (nf_ct_expect_related(exp) == 0)
break; break;
} }
@ -286,7 +286,7 @@ static unsigned int ip_nat_sdp(struct sk_buff **pskb,
return NF_DROP; return NF_DROP;
if (!mangle_sdp(pskb, ctinfo, ct, newip, port, dptr)) { if (!mangle_sdp(pskb, ctinfo, ct, newip, port, dptr)) {
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
return NF_DROP; return NF_DROP;
} }
return NF_ACCEPT; return NF_ACCEPT;

View File

@ -30,7 +30,7 @@ static unsigned int help(struct sk_buff **pskb,
= ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple.src.u.udp.port; = ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple.src.u.udp.port;
exp->dir = IP_CT_DIR_REPLY; exp->dir = IP_CT_DIR_REPLY;
exp->expectfn = nf_nat_follow_master; exp->expectfn = nf_nat_follow_master;
if (nf_conntrack_expect_related(exp) != 0) if (nf_ct_expect_related(exp) != 0)
return NF_DROP; return NF_DROP;
return NF_ACCEPT; return NF_ACCEPT;
} }

View File

@ -142,23 +142,22 @@ static int amanda_help(struct sk_buff **pskb,
if (port == 0 || len > 5) if (port == 0 || len > 5)
break; break;
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) { if (exp == NULL) {
ret = NF_DROP; ret = NF_DROP;
goto out; goto out;
} }
tuple = &ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple; tuple = &ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple;
nf_conntrack_expect_init(exp, family, nf_ct_expect_init(exp, family, &tuple->src.u3, &tuple->dst.u3,
&tuple->src.u3, &tuple->dst.u3, IPPROTO_TCP, NULL, &port);
IPPROTO_TCP, NULL, &port);
nf_nat_amanda = rcu_dereference(nf_nat_amanda_hook); nf_nat_amanda = rcu_dereference(nf_nat_amanda_hook);
if (nf_nat_amanda && ct->status & IPS_NAT_MASK) if (nf_nat_amanda && ct->status & IPS_NAT_MASK)
ret = nf_nat_amanda(pskb, ctinfo, off - dataoff, ret = nf_nat_amanda(pskb, ctinfo, off - dataoff,
len, exp); len, exp);
else if (nf_conntrack_expect_related(exp) != 0) else if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
out: out:

View File

@ -494,7 +494,7 @@ init_conntrack(const struct nf_conntrack_tuple *tuple,
} }
write_lock_bh(&nf_conntrack_lock); write_lock_bh(&nf_conntrack_lock);
exp = find_expectation(tuple); exp = nf_ct_find_expectation(tuple);
if (exp) { if (exp) {
DEBUGP("conntrack: expectation arrives ct=%p exp=%p\n", DEBUGP("conntrack: expectation arrives ct=%p exp=%p\n",
conntrack, exp); conntrack, exp);
@ -544,7 +544,7 @@ init_conntrack(const struct nf_conntrack_tuple *tuple,
if (exp) { if (exp) {
if (exp->expectfn) if (exp->expectfn)
exp->expectfn(conntrack, exp); exp->expectfn(conntrack, exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
return &conntrack->tuplehash[IP_CT_DIR_ORIGINAL]; return &conntrack->tuplehash[IP_CT_DIR_ORIGINAL];
@ -961,7 +961,7 @@ void nf_conntrack_cleanup(void)
rcu_assign_pointer(nf_ct_destroy, NULL); rcu_assign_pointer(nf_ct_destroy, NULL);
kmem_cache_destroy(nf_conntrack_cachep); kmem_cache_destroy(nf_conntrack_cachep);
kmem_cache_destroy(nf_conntrack_expect_cachep); kmem_cache_destroy(nf_ct_expect_cachep);
nf_ct_free_hashtable(nf_conntrack_hash, nf_conntrack_vmalloc, nf_ct_free_hashtable(nf_conntrack_hash, nf_conntrack_vmalloc,
nf_conntrack_htable_size); nf_conntrack_htable_size);
@ -1088,10 +1088,10 @@ int __init nf_conntrack_init(void)
goto err_free_hash; goto err_free_hash;
} }
nf_conntrack_expect_cachep = kmem_cache_create("nf_conntrack_expect", nf_ct_expect_cachep = kmem_cache_create("nf_conntrack_expect",
sizeof(struct nf_conntrack_expect), sizeof(struct nf_conntrack_expect),
0, 0, NULL, NULL); 0, 0, NULL, NULL);
if (!nf_conntrack_expect_cachep) { if (!nf_ct_expect_cachep) {
printk(KERN_ERR "Unable to create nf_expect slab cache\n"); printk(KERN_ERR "Unable to create nf_expect slab cache\n");
goto err_free_conntrack_slab; goto err_free_conntrack_slab;
} }
@ -1119,7 +1119,7 @@ int __init nf_conntrack_init(void)
out_fini_proto: out_fini_proto:
nf_conntrack_proto_fini(); nf_conntrack_proto_fini();
out_free_expect_slab: out_free_expect_slab:
kmem_cache_destroy(nf_conntrack_expect_cachep); kmem_cache_destroy(nf_ct_expect_cachep);
err_free_conntrack_slab: err_free_conntrack_slab:
kmem_cache_destroy(nf_conntrack_cachep); kmem_cache_destroy(nf_conntrack_cachep);
err_free_hash: err_free_hash:

View File

@ -26,8 +26,8 @@
ATOMIC_NOTIFIER_HEAD(nf_conntrack_chain); ATOMIC_NOTIFIER_HEAD(nf_conntrack_chain);
EXPORT_SYMBOL_GPL(nf_conntrack_chain); EXPORT_SYMBOL_GPL(nf_conntrack_chain);
ATOMIC_NOTIFIER_HEAD(nf_conntrack_expect_chain); ATOMIC_NOTIFIER_HEAD(nf_ct_expect_chain);
EXPORT_SYMBOL_GPL(nf_conntrack_expect_chain); EXPORT_SYMBOL_GPL(nf_ct_expect_chain);
DEFINE_PER_CPU(struct nf_conntrack_ecache, nf_conntrack_ecache); DEFINE_PER_CPU(struct nf_conntrack_ecache, nf_conntrack_ecache);
EXPORT_PER_CPU_SYMBOL_GPL(nf_conntrack_ecache); EXPORT_PER_CPU_SYMBOL_GPL(nf_conntrack_ecache);
@ -103,14 +103,14 @@ int nf_conntrack_unregister_notifier(struct notifier_block *nb)
} }
EXPORT_SYMBOL_GPL(nf_conntrack_unregister_notifier); EXPORT_SYMBOL_GPL(nf_conntrack_unregister_notifier);
int nf_conntrack_expect_register_notifier(struct notifier_block *nb) int nf_ct_expect_register_notifier(struct notifier_block *nb)
{ {
return atomic_notifier_chain_register(&nf_conntrack_expect_chain, nb); return atomic_notifier_chain_register(&nf_ct_expect_chain, nb);
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_register_notifier); EXPORT_SYMBOL_GPL(nf_ct_expect_register_notifier);
int nf_conntrack_expect_unregister_notifier(struct notifier_block *nb) int nf_ct_expect_unregister_notifier(struct notifier_block *nb)
{ {
return atomic_notifier_chain_unregister(&nf_conntrack_expect_chain, nb); return atomic_notifier_chain_unregister(&nf_ct_expect_chain, nb);
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_unregister_notifier); EXPORT_SYMBOL_GPL(nf_ct_expect_unregister_notifier);

View File

@ -26,11 +26,11 @@
#include <net/netfilter/nf_conntrack_helper.h> #include <net/netfilter/nf_conntrack_helper.h>
#include <net/netfilter/nf_conntrack_tuple.h> #include <net/netfilter/nf_conntrack_tuple.h>
LIST_HEAD(nf_conntrack_expect_list); LIST_HEAD(nf_ct_expect_list);
EXPORT_SYMBOL_GPL(nf_conntrack_expect_list); EXPORT_SYMBOL_GPL(nf_ct_expect_list);
struct kmem_cache *nf_conntrack_expect_cachep __read_mostly; struct kmem_cache *nf_ct_expect_cachep __read_mostly;
static unsigned int nf_conntrack_expect_next_id; static unsigned int nf_ct_expect_next_id;
/* nf_conntrack_expect helper functions */ /* nf_conntrack_expect helper functions */
void nf_ct_unlink_expect(struct nf_conntrack_expect *exp) void nf_ct_unlink_expect(struct nf_conntrack_expect *exp)
@ -43,57 +43,57 @@ void nf_ct_unlink_expect(struct nf_conntrack_expect *exp)
list_del(&exp->list); list_del(&exp->list);
NF_CT_STAT_INC(expect_delete); NF_CT_STAT_INC(expect_delete);
master_help->expecting--; master_help->expecting--;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
EXPORT_SYMBOL_GPL(nf_ct_unlink_expect); EXPORT_SYMBOL_GPL(nf_ct_unlink_expect);
static void expectation_timed_out(unsigned long ul_expect) static void nf_ct_expectation_timed_out(unsigned long ul_expect)
{ {
struct nf_conntrack_expect *exp = (void *)ul_expect; struct nf_conntrack_expect *exp = (void *)ul_expect;
write_lock_bh(&nf_conntrack_lock); write_lock_bh(&nf_conntrack_lock);
nf_ct_unlink_expect(exp); nf_ct_unlink_expect(exp);
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
struct nf_conntrack_expect * struct nf_conntrack_expect *
__nf_conntrack_expect_find(const struct nf_conntrack_tuple *tuple) __nf_ct_expect_find(const struct nf_conntrack_tuple *tuple)
{ {
struct nf_conntrack_expect *i; struct nf_conntrack_expect *i;
list_for_each_entry(i, &nf_conntrack_expect_list, list) { list_for_each_entry(i, &nf_ct_expect_list, list) {
if (nf_ct_tuple_mask_cmp(tuple, &i->tuple, &i->mask)) if (nf_ct_tuple_mask_cmp(tuple, &i->tuple, &i->mask))
return i; return i;
} }
return NULL; return NULL;
} }
EXPORT_SYMBOL_GPL(__nf_conntrack_expect_find); EXPORT_SYMBOL_GPL(__nf_ct_expect_find);
/* Just find a expectation corresponding to a tuple. */ /* Just find a expectation corresponding to a tuple. */
struct nf_conntrack_expect * struct nf_conntrack_expect *
nf_conntrack_expect_find_get(const struct nf_conntrack_tuple *tuple) nf_ct_expect_find_get(const struct nf_conntrack_tuple *tuple)
{ {
struct nf_conntrack_expect *i; struct nf_conntrack_expect *i;
read_lock_bh(&nf_conntrack_lock); read_lock_bh(&nf_conntrack_lock);
i = __nf_conntrack_expect_find(tuple); i = __nf_ct_expect_find(tuple);
if (i) if (i)
atomic_inc(&i->use); atomic_inc(&i->use);
read_unlock_bh(&nf_conntrack_lock); read_unlock_bh(&nf_conntrack_lock);
return i; return i;
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_find_get); EXPORT_SYMBOL_GPL(nf_ct_expect_find_get);
/* If an expectation for this connection is found, it gets delete from /* If an expectation for this connection is found, it gets delete from
* global list then returned. */ * global list then returned. */
struct nf_conntrack_expect * struct nf_conntrack_expect *
find_expectation(const struct nf_conntrack_tuple *tuple) nf_ct_find_expectation(const struct nf_conntrack_tuple *tuple)
{ {
struct nf_conntrack_expect *exp; struct nf_conntrack_expect *exp;
exp = __nf_conntrack_expect_find(tuple); exp = __nf_ct_expect_find(tuple);
if (!exp) if (!exp)
return NULL; return NULL;
@ -126,10 +126,10 @@ void nf_ct_remove_expectations(struct nf_conn *ct)
if (!help || help->expecting == 0) if (!help || help->expecting == 0)
return; return;
list_for_each_entry_safe(i, tmp, &nf_conntrack_expect_list, list) { list_for_each_entry_safe(i, tmp, &nf_ct_expect_list, list) {
if (i->master == ct && del_timer(&i->timeout)) { if (i->master == ct && del_timer(&i->timeout)) {
nf_ct_unlink_expect(i); nf_ct_unlink_expect(i);
nf_conntrack_expect_put(i); nf_ct_expect_put(i);
} }
} }
} }
@ -172,32 +172,32 @@ static inline int expect_matches(const struct nf_conntrack_expect *a,
} }
/* Generally a bad idea to call this: could have matched already. */ /* Generally a bad idea to call this: could have matched already. */
void nf_conntrack_unexpect_related(struct nf_conntrack_expect *exp) void nf_ct_unexpect_related(struct nf_conntrack_expect *exp)
{ {
struct nf_conntrack_expect *i; struct nf_conntrack_expect *i;
write_lock_bh(&nf_conntrack_lock); write_lock_bh(&nf_conntrack_lock);
/* choose the oldest expectation to evict */ /* choose the oldest expectation to evict */
list_for_each_entry_reverse(i, &nf_conntrack_expect_list, list) { list_for_each_entry_reverse(i, &nf_ct_expect_list, list) {
if (expect_matches(i, exp) && del_timer(&i->timeout)) { if (expect_matches(i, exp) && del_timer(&i->timeout)) {
nf_ct_unlink_expect(i); nf_ct_unlink_expect(i);
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
nf_conntrack_expect_put(i); nf_ct_expect_put(i);
return; return;
} }
} }
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
} }
EXPORT_SYMBOL_GPL(nf_conntrack_unexpect_related); EXPORT_SYMBOL_GPL(nf_ct_unexpect_related);
/* We don't increase the master conntrack refcount for non-fulfilled /* We don't increase the master conntrack refcount for non-fulfilled
* conntracks. During the conntrack destruction, the expectations are * conntracks. During the conntrack destruction, the expectations are
* always killed before the conntrack itself */ * always killed before the conntrack itself */
struct nf_conntrack_expect *nf_conntrack_expect_alloc(struct nf_conn *me) struct nf_conntrack_expect *nf_ct_expect_alloc(struct nf_conn *me)
{ {
struct nf_conntrack_expect *new; struct nf_conntrack_expect *new;
new = kmem_cache_alloc(nf_conntrack_expect_cachep, GFP_ATOMIC); new = kmem_cache_alloc(nf_ct_expect_cachep, GFP_ATOMIC);
if (!new) if (!new)
return NULL; return NULL;
@ -205,12 +205,12 @@ struct nf_conntrack_expect *nf_conntrack_expect_alloc(struct nf_conn *me)
atomic_set(&new->use, 1); atomic_set(&new->use, 1);
return new; return new;
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_alloc); EXPORT_SYMBOL_GPL(nf_ct_expect_alloc);
void nf_conntrack_expect_init(struct nf_conntrack_expect *exp, int family, void nf_ct_expect_init(struct nf_conntrack_expect *exp, int family,
union nf_conntrack_address *saddr, union nf_conntrack_address *saddr,
union nf_conntrack_address *daddr, union nf_conntrack_address *daddr,
u_int8_t proto, __be16 *src, __be16 *dst) u_int8_t proto, __be16 *src, __be16 *dst)
{ {
int len; int len;
@ -273,28 +273,29 @@ void nf_conntrack_expect_init(struct nf_conntrack_expect *exp, int family,
exp->mask.dst.u.all = 0; exp->mask.dst.u.all = 0;
} }
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_init); EXPORT_SYMBOL_GPL(nf_ct_expect_init);
void nf_conntrack_expect_put(struct nf_conntrack_expect *exp) void nf_ct_expect_put(struct nf_conntrack_expect *exp)
{ {
if (atomic_dec_and_test(&exp->use)) if (atomic_dec_and_test(&exp->use))
kmem_cache_free(nf_conntrack_expect_cachep, exp); kmem_cache_free(nf_ct_expect_cachep, exp);
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_put); EXPORT_SYMBOL_GPL(nf_ct_expect_put);
static void nf_conntrack_expect_insert(struct nf_conntrack_expect *exp) static void nf_ct_expect_insert(struct nf_conntrack_expect *exp)
{ {
struct nf_conn_help *master_help = nfct_help(exp->master); struct nf_conn_help *master_help = nfct_help(exp->master);
atomic_inc(&exp->use); atomic_inc(&exp->use);
master_help->expecting++; master_help->expecting++;
list_add(&exp->list, &nf_conntrack_expect_list); list_add(&exp->list, &nf_ct_expect_list);
setup_timer(&exp->timeout, expectation_timed_out, (unsigned long)exp); setup_timer(&exp->timeout, nf_ct_expectation_timed_out,
(unsigned long)exp);
exp->timeout.expires = jiffies + master_help->helper->timeout * HZ; exp->timeout.expires = jiffies + master_help->helper->timeout * HZ;
add_timer(&exp->timeout); add_timer(&exp->timeout);
exp->id = ++nf_conntrack_expect_next_id; exp->id = ++nf_ct_expect_next_id;
atomic_inc(&exp->use); atomic_inc(&exp->use);
NF_CT_STAT_INC(expect_create); NF_CT_STAT_INC(expect_create);
} }
@ -304,11 +305,11 @@ static void evict_oldest_expect(struct nf_conn *master)
{ {
struct nf_conntrack_expect *i; struct nf_conntrack_expect *i;
list_for_each_entry_reverse(i, &nf_conntrack_expect_list, list) { list_for_each_entry_reverse(i, &nf_ct_expect_list, list) {
if (i->master == master) { if (i->master == master) {
if (del_timer(&i->timeout)) { if (del_timer(&i->timeout)) {
nf_ct_unlink_expect(i); nf_ct_unlink_expect(i);
nf_conntrack_expect_put(i); nf_ct_expect_put(i);
} }
break; break;
} }
@ -327,7 +328,7 @@ static inline int refresh_timer(struct nf_conntrack_expect *i)
return 1; return 1;
} }
int nf_conntrack_expect_related(struct nf_conntrack_expect *expect) int nf_ct_expect_related(struct nf_conntrack_expect *expect)
{ {
struct nf_conntrack_expect *i; struct nf_conntrack_expect *i;
struct nf_conn *master = expect->master; struct nf_conn *master = expect->master;
@ -341,7 +342,7 @@ int nf_conntrack_expect_related(struct nf_conntrack_expect *expect)
ret = -ESHUTDOWN; ret = -ESHUTDOWN;
goto out; goto out;
} }
list_for_each_entry(i, &nf_conntrack_expect_list, list) { list_for_each_entry(i, &nf_ct_expect_list, list) {
if (expect_matches(i, expect)) { if (expect_matches(i, expect)) {
/* Refresh timer: if it's dying, ignore.. */ /* Refresh timer: if it's dying, ignore.. */
if (refresh_timer(i)) { if (refresh_timer(i)) {
@ -358,19 +359,19 @@ int nf_conntrack_expect_related(struct nf_conntrack_expect *expect)
master_help->expecting >= master_help->helper->max_expected) master_help->expecting >= master_help->helper->max_expected)
evict_oldest_expect(master); evict_oldest_expect(master);
nf_conntrack_expect_insert(expect); nf_ct_expect_insert(expect);
nf_conntrack_expect_event(IPEXP_NEW, expect); nf_ct_expect_event(IPEXP_NEW, expect);
ret = 0; ret = 0;
out: out:
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
return ret; return ret;
} }
EXPORT_SYMBOL_GPL(nf_conntrack_expect_related); EXPORT_SYMBOL_GPL(nf_ct_expect_related);
#ifdef CONFIG_PROC_FS #ifdef CONFIG_PROC_FS
static void *exp_seq_start(struct seq_file *s, loff_t *pos) static void *exp_seq_start(struct seq_file *s, loff_t *pos)
{ {
struct list_head *e = &nf_conntrack_expect_list; struct list_head *e = &nf_ct_expect_list;
loff_t i; loff_t i;
/* strange seq_file api calls stop even if we fail, /* strange seq_file api calls stop even if we fail,
@ -382,7 +383,7 @@ static void *exp_seq_start(struct seq_file *s, loff_t *pos)
for (i = 0; i <= *pos; i++) { for (i = 0; i <= *pos; i++) {
e = e->next; e = e->next;
if (e == &nf_conntrack_expect_list) if (e == &nf_ct_expect_list)
return NULL; return NULL;
} }
return e; return e;
@ -395,7 +396,7 @@ static void *exp_seq_next(struct seq_file *s, void *v, loff_t *pos)
++*pos; ++*pos;
e = e->next; e = e->next;
if (e == &nf_conntrack_expect_list) if (e == &nf_ct_expect_list)
return NULL; return NULL;
return e; return e;

View File

@ -445,7 +445,7 @@ static int help(struct sk_buff **pskb,
(int)matchlen, fb_ptr + matchoff, (int)matchlen, fb_ptr + matchoff,
matchlen, ntohl(th->seq) + matchoff); matchlen, ntohl(th->seq) + matchoff);
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) { if (exp == NULL) {
ret = NF_DROP; ret = NF_DROP;
goto out; goto out;
@ -523,14 +523,14 @@ static int help(struct sk_buff **pskb,
matchoff, matchlen, exp); matchoff, matchlen, exp);
else { else {
/* Can't expect this? Best to drop packet now. */ /* Can't expect this? Best to drop packet now. */
if (nf_conntrack_expect_related(exp) != 0) if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
else else
ret = NF_ACCEPT; ret = NF_ACCEPT;
} }
out_put_expect: out_put_expect:
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
out_update_nl: out_update_nl:
/* Now if this ends in \n, update ftp info. Seq may have been /* Now if this ends in \n, update ftp info. Seq may have been

View File

@ -282,22 +282,22 @@ static int expect_rtp_rtcp(struct sk_buff **pskb, struct nf_conn *ct,
rtcp_port = htons(ntohs(port) + 1); rtcp_port = htons(ntohs(port) + 1);
/* Create expect for RTP */ /* Create expect for RTP */
if ((rtp_exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((rtp_exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(rtp_exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(rtp_exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &ct->tuplehash[!dir].tuple.src.u3,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
IPPROTO_UDP, NULL, &rtp_port); IPPROTO_UDP, NULL, &rtp_port);
/* Create expect for RTCP */ /* Create expect for RTCP */
if ((rtcp_exp = nf_conntrack_expect_alloc(ct)) == NULL) { if ((rtcp_exp = nf_ct_expect_alloc(ct)) == NULL) {
nf_conntrack_expect_put(rtp_exp); nf_ct_expect_put(rtp_exp);
return -1; return -1;
} }
nf_conntrack_expect_init(rtcp_exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(rtcp_exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &ct->tuplehash[!dir].tuple.src.u3,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
IPPROTO_UDP, NULL, &rtcp_port); IPPROTO_UDP, NULL, &rtcp_port);
if (memcmp(&ct->tuplehash[dir].tuple.src.u3, if (memcmp(&ct->tuplehash[dir].tuple.src.u3,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
@ -308,22 +308,22 @@ static int expect_rtp_rtcp(struct sk_buff **pskb, struct nf_conn *ct,
ret = nat_rtp_rtcp(pskb, ct, ctinfo, data, dataoff, ret = nat_rtp_rtcp(pskb, ct, ctinfo, data, dataoff,
taddr, port, rtp_port, rtp_exp, rtcp_exp); taddr, port, rtp_port, rtp_exp, rtcp_exp);
} else { /* Conntrack only */ } else { /* Conntrack only */
if (nf_conntrack_expect_related(rtp_exp) == 0) { if (nf_ct_expect_related(rtp_exp) == 0) {
if (nf_conntrack_expect_related(rtcp_exp) == 0) { if (nf_ct_expect_related(rtcp_exp) == 0) {
DEBUGP("nf_ct_h323: expect RTP "); DEBUGP("nf_ct_h323: expect RTP ");
NF_CT_DUMP_TUPLE(&rtp_exp->tuple); NF_CT_DUMP_TUPLE(&rtp_exp->tuple);
DEBUGP("nf_ct_h323: expect RTCP "); DEBUGP("nf_ct_h323: expect RTCP ");
NF_CT_DUMP_TUPLE(&rtcp_exp->tuple); NF_CT_DUMP_TUPLE(&rtcp_exp->tuple);
} else { } else {
nf_conntrack_unexpect_related(rtp_exp); nf_ct_unexpect_related(rtp_exp);
ret = -1; ret = -1;
} }
} else } else
ret = -1; ret = -1;
} }
nf_conntrack_expect_put(rtp_exp); nf_ct_expect_put(rtp_exp);
nf_conntrack_expect_put(rtcp_exp); nf_ct_expect_put(rtcp_exp);
return ret; return ret;
} }
@ -349,12 +349,12 @@ static int expect_t120(struct sk_buff **pskb,
return 0; return 0;
/* Create expect for T.120 connections */ /* Create expect for T.120 connections */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &ct->tuplehash[!dir].tuple.src.u3,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
exp->flags = NF_CT_EXPECT_PERMANENT; /* Accept multiple channels */ exp->flags = NF_CT_EXPECT_PERMANENT; /* Accept multiple channels */
if (memcmp(&ct->tuplehash[dir].tuple.src.u3, if (memcmp(&ct->tuplehash[dir].tuple.src.u3,
@ -366,14 +366,14 @@ static int expect_t120(struct sk_buff **pskb,
ret = nat_t120(pskb, ct, ctinfo, data, dataoff, taddr, ret = nat_t120(pskb, ct, ctinfo, data, dataoff, taddr,
port, exp); port, exp);
} else { /* Conntrack only */ } else { /* Conntrack only */
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_h323: expect T.120 "); DEBUGP("nf_ct_h323: expect T.120 ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
} }
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -684,12 +684,12 @@ static int expect_h245(struct sk_buff **pskb, struct nf_conn *ct,
return 0; return 0;
/* Create expect for h245 connection */ /* Create expect for h245 connection */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &ct->tuplehash[!dir].tuple.src.u3,
&ct->tuplehash[!dir].tuple.dst.u3, &ct->tuplehash[!dir].tuple.dst.u3,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
exp->helper = &nf_conntrack_helper_h245; exp->helper = &nf_conntrack_helper_h245;
if (memcmp(&ct->tuplehash[dir].tuple.src.u3, if (memcmp(&ct->tuplehash[dir].tuple.src.u3,
@ -701,14 +701,14 @@ static int expect_h245(struct sk_buff **pskb, struct nf_conn *ct,
ret = nat_h245(pskb, ct, ctinfo, data, dataoff, taddr, ret = nat_h245(pskb, ct, ctinfo, data, dataoff, taddr,
port, exp); port, exp);
} else { /* Conntrack only */ } else { /* Conntrack only */
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_q931: expect H.245 "); DEBUGP("nf_ct_q931: expect H.245 ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
} }
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -796,11 +796,11 @@ static int expect_callforwarding(struct sk_buff **pskb,
} }
/* Create expect for the second call leg */ /* Create expect for the second call leg */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &addr, &ct->tuplehash[!dir].tuple.src.u3, &addr,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
exp->helper = nf_conntrack_helper_q931; exp->helper = nf_conntrack_helper_q931;
if (memcmp(&ct->tuplehash[dir].tuple.src.u3, if (memcmp(&ct->tuplehash[dir].tuple.src.u3,
@ -812,14 +812,14 @@ static int expect_callforwarding(struct sk_buff **pskb,
ret = nat_callforwarding(pskb, ct, ctinfo, data, dataoff, ret = nat_callforwarding(pskb, ct, ctinfo, data, dataoff,
taddr, port, exp); taddr, port, exp);
} else { /* Conntrack only */ } else { /* Conntrack only */
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_q931: expect Call Forwarding "); DEBUGP("nf_ct_q931: expect Call Forwarding ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
} }
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -1225,7 +1225,7 @@ static struct nf_conntrack_expect *find_expect(struct nf_conn *ct,
tuple.dst.u.tcp.port = port; tuple.dst.u.tcp.port = port;
tuple.dst.protonum = IPPROTO_TCP; tuple.dst.protonum = IPPROTO_TCP;
exp = __nf_conntrack_expect_find(&tuple); exp = __nf_ct_expect_find(&tuple);
if (exp && exp->master == ct) if (exp && exp->master == ct)
return exp; return exp;
return NULL; return NULL;
@ -1271,14 +1271,13 @@ static int expect_q931(struct sk_buff **pskb, struct nf_conn *ct,
return 0; return 0;
/* Create expect for Q.931 */ /* Create expect for Q.931 */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
gkrouted_only ? /* only accept calls from GK? */ gkrouted_only ? /* only accept calls from GK? */
&ct->tuplehash[!dir].tuple.src.u3 : &ct->tuplehash[!dir].tuple.src.u3 : NULL,
NULL, &ct->tuplehash[!dir].tuple.dst.u3,
&ct->tuplehash[!dir].tuple.dst.u3, IPPROTO_TCP, NULL, &port);
IPPROTO_TCP, NULL, &port);
exp->helper = nf_conntrack_helper_q931; exp->helper = nf_conntrack_helper_q931;
exp->flags = NF_CT_EXPECT_PERMANENT; /* Accept multiple calls */ exp->flags = NF_CT_EXPECT_PERMANENT; /* Accept multiple calls */
@ -1286,7 +1285,7 @@ static int expect_q931(struct sk_buff **pskb, struct nf_conn *ct,
if (nat_q931 && ct->status & IPS_NAT_MASK) { /* Need NAT */ if (nat_q931 && ct->status & IPS_NAT_MASK) { /* Need NAT */
ret = nat_q931(pskb, ct, ctinfo, data, taddr, i, port, exp); ret = nat_q931(pskb, ct, ctinfo, data, taddr, i, port, exp);
} else { /* Conntrack only */ } else { /* Conntrack only */
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_ras: expect Q.931 "); DEBUGP("nf_ct_ras: expect Q.931 ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
@ -1296,7 +1295,7 @@ static int expect_q931(struct sk_buff **pskb, struct nf_conn *ct,
ret = -1; ret = -1;
} }
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -1343,20 +1342,20 @@ static int process_gcf(struct sk_buff **pskb, struct nf_conn *ct,
return 0; return 0;
/* Need new expect */ /* Need new expect */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &addr, &ct->tuplehash[!dir].tuple.src.u3, &addr,
IPPROTO_UDP, NULL, &port); IPPROTO_UDP, NULL, &port);
exp->helper = nf_conntrack_helper_ras; exp->helper = nf_conntrack_helper_ras;
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_ras: expect RAS "); DEBUGP("nf_ct_ras: expect RAS ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -1548,21 +1547,21 @@ static int process_acf(struct sk_buff **pskb, struct nf_conn *ct,
} }
/* Need new expect */ /* Need new expect */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &addr, &ct->tuplehash[!dir].tuple.src.u3, &addr,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
exp->flags = NF_CT_EXPECT_PERMANENT; exp->flags = NF_CT_EXPECT_PERMANENT;
exp->helper = nf_conntrack_helper_q931; exp->helper = nf_conntrack_helper_q931;
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_ras: expect Q.931 "); DEBUGP("nf_ct_ras: expect Q.931 ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }
@ -1601,21 +1600,21 @@ static int process_lcf(struct sk_buff **pskb, struct nf_conn *ct,
return 0; return 0;
/* Need new expect for call signal */ /* Need new expect for call signal */
if ((exp = nf_conntrack_expect_alloc(ct)) == NULL) if ((exp = nf_ct_expect_alloc(ct)) == NULL)
return -1; return -1;
nf_conntrack_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num, nf_ct_expect_init(exp, ct->tuplehash[!dir].tuple.src.l3num,
&ct->tuplehash[!dir].tuple.src.u3, &addr, &ct->tuplehash[!dir].tuple.src.u3, &addr,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
exp->flags = NF_CT_EXPECT_PERMANENT; exp->flags = NF_CT_EXPECT_PERMANENT;
exp->helper = nf_conntrack_helper_q931; exp->helper = nf_conntrack_helper_q931;
if (nf_conntrack_expect_related(exp) == 0) { if (nf_ct_expect_related(exp) == 0) {
DEBUGP("nf_ct_ras: expect Q.931 "); DEBUGP("nf_ct_ras: expect Q.931 ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
} else } else
ret = -1; ret = -1;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
/* Ignore rasAddress */ /* Ignore rasAddress */

View File

@ -123,12 +123,12 @@ void nf_conntrack_helper_unregister(struct nf_conntrack_helper *me)
list_del(&me->list); list_del(&me->list);
/* Get rid of expectations */ /* Get rid of expectations */
list_for_each_entry_safe(exp, tmp, &nf_conntrack_expect_list, list) { list_for_each_entry_safe(exp, tmp, &nf_ct_expect_list, list) {
struct nf_conn_help *help = nfct_help(exp->master); struct nf_conn_help *help = nfct_help(exp->master);
if ((help->helper == me || exp->helper == me) && if ((help->helper == me || exp->helper == me) &&
del_timer(&exp->timeout)) { del_timer(&exp->timeout)) {
nf_ct_unlink_expect(exp); nf_ct_unlink_expect(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
} }

View File

@ -184,16 +184,16 @@ static int help(struct sk_buff **pskb, unsigned int protoff,
continue; continue;
} }
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) { if (exp == NULL) {
ret = NF_DROP; ret = NF_DROP;
goto out; goto out;
} }
tuple = &ct->tuplehash[!dir].tuple; tuple = &ct->tuplehash[!dir].tuple;
port = htons(dcc_port); port = htons(dcc_port);
nf_conntrack_expect_init(exp, tuple->src.l3num, nf_ct_expect_init(exp, tuple->src.l3num,
NULL, &tuple->dst.u3, NULL, &tuple->dst.u3,
IPPROTO_TCP, NULL, &port); IPPROTO_TCP, NULL, &port);
nf_nat_irc = rcu_dereference(nf_nat_irc_hook); nf_nat_irc = rcu_dereference(nf_nat_irc_hook);
if (nf_nat_irc && ct->status & IPS_NAT_MASK) if (nf_nat_irc && ct->status & IPS_NAT_MASK)
@ -201,9 +201,9 @@ static int help(struct sk_buff **pskb, unsigned int protoff,
addr_beg_p - ib_ptr, addr_beg_p - ib_ptr,
addr_end_p - addr_beg_p, addr_end_p - addr_beg_p,
exp); exp);
else if (nf_conntrack_expect_related(exp) != 0) else if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
goto out; goto out;
} }
} }

View File

@ -74,7 +74,7 @@ static int help(struct sk_buff **pskb, unsigned int protoff,
if (mask == 0) if (mask == 0)
goto out; goto out;
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) if (exp == NULL)
goto out; goto out;
@ -91,8 +91,8 @@ static int help(struct sk_buff **pskb, unsigned int protoff,
exp->flags = NF_CT_EXPECT_PERMANENT; exp->flags = NF_CT_EXPECT_PERMANENT;
exp->helper = NULL; exp->helper = NULL;
nf_conntrack_expect_related(exp); nf_ct_expect_related(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
nf_ct_refresh(ct, *pskb, timeout * HZ); nf_ct_refresh(ct, *pskb, timeout * HZ);
out: out:

View File

@ -1239,7 +1239,7 @@ ctnetlink_exp_dump_table(struct sk_buff *skb, struct netlink_callback *cb)
u_int8_t l3proto = nfmsg->nfgen_family; u_int8_t l3proto = nfmsg->nfgen_family;
read_lock_bh(&nf_conntrack_lock); read_lock_bh(&nf_conntrack_lock);
list_for_each_prev(i, &nf_conntrack_expect_list) { list_for_each_prev(i, &nf_ct_expect_list) {
exp = (struct nf_conntrack_expect *) i; exp = (struct nf_conntrack_expect *) i;
if (l3proto && exp->tuple.src.l3num != l3proto) if (l3proto && exp->tuple.src.l3num != l3proto)
continue; continue;
@ -1291,14 +1291,14 @@ ctnetlink_get_expect(struct sock *ctnl, struct sk_buff *skb,
if (err < 0) if (err < 0)
return err; return err;
exp = nf_conntrack_expect_find_get(&tuple); exp = nf_ct_expect_find_get(&tuple);
if (!exp) if (!exp)
return -ENOENT; return -ENOENT;
if (cda[CTA_EXPECT_ID-1]) { if (cda[CTA_EXPECT_ID-1]) {
__be32 id = *(__be32 *)NFA_DATA(cda[CTA_EXPECT_ID-1]); __be32 id = *(__be32 *)NFA_DATA(cda[CTA_EXPECT_ID-1]);
if (exp->id != ntohl(id)) { if (exp->id != ntohl(id)) {
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return -ENOENT; return -ENOENT;
} }
} }
@ -1314,14 +1314,14 @@ ctnetlink_get_expect(struct sock *ctnl, struct sk_buff *skb,
if (err <= 0) if (err <= 0)
goto free; goto free;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT); return netlink_unicast(ctnl, skb2, NETLINK_CB(skb).pid, MSG_DONTWAIT);
free: free:
kfree_skb(skb2); kfree_skb(skb2);
out: out:
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return err; return err;
} }
@ -1346,23 +1346,23 @@ ctnetlink_del_expect(struct sock *ctnl, struct sk_buff *skb,
return err; return err;
/* bump usage count to 2 */ /* bump usage count to 2 */
exp = nf_conntrack_expect_find_get(&tuple); exp = nf_ct_expect_find_get(&tuple);
if (!exp) if (!exp)
return -ENOENT; return -ENOENT;
if (cda[CTA_EXPECT_ID-1]) { if (cda[CTA_EXPECT_ID-1]) {
__be32 id = *(__be32 *)NFA_DATA(cda[CTA_EXPECT_ID-1]); __be32 id = *(__be32 *)NFA_DATA(cda[CTA_EXPECT_ID-1]);
if (exp->id != ntohl(id)) { if (exp->id != ntohl(id)) {
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return -ENOENT; return -ENOENT;
} }
} }
/* after list removal, usage count == 1 */ /* after list removal, usage count == 1 */
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
/* have to put what we 'get' above. /* have to put what we 'get' above.
* after this line usage count == 0 */ * after this line usage count == 0 */
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} else if (cda[CTA_EXPECT_HELP_NAME-1]) { } else if (cda[CTA_EXPECT_HELP_NAME-1]) {
char *name = NFA_DATA(cda[CTA_EXPECT_HELP_NAME-1]); char *name = NFA_DATA(cda[CTA_EXPECT_HELP_NAME-1]);
@ -1373,24 +1373,22 @@ ctnetlink_del_expect(struct sock *ctnl, struct sk_buff *skb,
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
return -EINVAL; return -EINVAL;
} }
list_for_each_entry_safe(exp, tmp, &nf_conntrack_expect_list, list_for_each_entry_safe(exp, tmp, &nf_ct_expect_list, list) {
list) {
struct nf_conn_help *m_help = nfct_help(exp->master); struct nf_conn_help *m_help = nfct_help(exp->master);
if (m_help->helper == h if (m_help->helper == h
&& del_timer(&exp->timeout)) { && del_timer(&exp->timeout)) {
nf_ct_unlink_expect(exp); nf_ct_unlink_expect(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
} }
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
} else { } else {
/* This basically means we have to flush everything*/ /* This basically means we have to flush everything*/
write_lock_bh(&nf_conntrack_lock); write_lock_bh(&nf_conntrack_lock);
list_for_each_entry_safe(exp, tmp, &nf_conntrack_expect_list, list_for_each_entry_safe(exp, tmp, &nf_ct_expect_list, list) {
list) {
if (del_timer(&exp->timeout)) { if (del_timer(&exp->timeout)) {
nf_ct_unlink_expect(exp); nf_ct_unlink_expect(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
} }
} }
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
@ -1438,7 +1436,7 @@ ctnetlink_create_expect(struct nfattr *cda[], u_int8_t u3)
goto out; goto out;
} }
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (!exp) { if (!exp) {
err = -ENOMEM; err = -ENOMEM;
goto out; goto out;
@ -1451,8 +1449,8 @@ ctnetlink_create_expect(struct nfattr *cda[], u_int8_t u3)
memcpy(&exp->tuple, &tuple, sizeof(struct nf_conntrack_tuple)); memcpy(&exp->tuple, &tuple, sizeof(struct nf_conntrack_tuple));
memcpy(&exp->mask, &mask, sizeof(struct nf_conntrack_tuple)); memcpy(&exp->mask, &mask, sizeof(struct nf_conntrack_tuple));
err = nf_conntrack_expect_related(exp); err = nf_ct_expect_related(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
out: out:
nf_ct_put(nf_ct_tuplehash_to_ctrack(h)); nf_ct_put(nf_ct_tuplehash_to_ctrack(h));
@ -1482,7 +1480,7 @@ ctnetlink_new_expect(struct sock *ctnl, struct sk_buff *skb,
return err; return err;
write_lock_bh(&nf_conntrack_lock); write_lock_bh(&nf_conntrack_lock);
exp = __nf_conntrack_expect_find(&tuple); exp = __nf_ct_expect_find(&tuple);
if (!exp) { if (!exp) {
write_unlock_bh(&nf_conntrack_lock); write_unlock_bh(&nf_conntrack_lock);
@ -1572,7 +1570,7 @@ static int __init ctnetlink_init(void)
goto err_unreg_exp_subsys; goto err_unreg_exp_subsys;
} }
ret = nf_conntrack_expect_register_notifier(&ctnl_notifier_exp); ret = nf_ct_expect_register_notifier(&ctnl_notifier_exp);
if (ret < 0) { if (ret < 0) {
printk("ctnetlink_init: cannot expect register notifier.\n"); printk("ctnetlink_init: cannot expect register notifier.\n");
goto err_unreg_notifier; goto err_unreg_notifier;
@ -1598,7 +1596,7 @@ static void __exit ctnetlink_exit(void)
printk("ctnetlink: unregistering from nfnetlink.\n"); printk("ctnetlink: unregistering from nfnetlink.\n");
#ifdef CONFIG_NF_CONNTRACK_EVENTS #ifdef CONFIG_NF_CONNTRACK_EVENTS
nf_conntrack_expect_unregister_notifier(&ctnl_notifier_exp); nf_ct_expect_unregister_notifier(&ctnl_notifier_exp);
nf_conntrack_unregister_notifier(&ctnl_notifier); nf_conntrack_unregister_notifier(&ctnl_notifier);
#endif #endif

View File

@ -124,12 +124,12 @@ static void pptp_expectfn(struct nf_conn *ct,
DEBUGP("trying to unexpect other dir: "); DEBUGP("trying to unexpect other dir: ");
NF_CT_DUMP_TUPLE(&inv_t); NF_CT_DUMP_TUPLE(&inv_t);
exp_other = nf_conntrack_expect_find_get(&inv_t); exp_other = nf_ct_expect_find_get(&inv_t);
if (exp_other) { if (exp_other) {
/* delete other expectation. */ /* delete other expectation. */
DEBUGP("found\n"); DEBUGP("found\n");
nf_conntrack_unexpect_related(exp_other); nf_ct_unexpect_related(exp_other);
nf_conntrack_expect_put(exp_other); nf_ct_expect_put(exp_other);
} else { } else {
DEBUGP("not found\n"); DEBUGP("not found\n");
} }
@ -157,11 +157,11 @@ static int destroy_sibling_or_exp(const struct nf_conntrack_tuple *t)
nf_ct_put(sibling); nf_ct_put(sibling);
return 1; return 1;
} else { } else {
exp = nf_conntrack_expect_find_get(t); exp = nf_ct_expect_find_get(t);
if (exp) { if (exp) {
DEBUGP("unexpect_related of expect %p\n", exp); DEBUGP("unexpect_related of expect %p\n", exp);
nf_conntrack_unexpect_related(exp); nf_ct_unexpect_related(exp);
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return 1; return 1;
} }
} }
@ -201,36 +201,36 @@ static int exp_gre(struct nf_conn *ct, __be16 callid, __be16 peer_callid)
int ret = 1; int ret = 1;
typeof(nf_nat_pptp_hook_exp_gre) nf_nat_pptp_exp_gre; typeof(nf_nat_pptp_hook_exp_gre) nf_nat_pptp_exp_gre;
exp_orig = nf_conntrack_expect_alloc(ct); exp_orig = nf_ct_expect_alloc(ct);
if (exp_orig == NULL) if (exp_orig == NULL)
goto out; goto out;
exp_reply = nf_conntrack_expect_alloc(ct); exp_reply = nf_ct_expect_alloc(ct);
if (exp_reply == NULL) if (exp_reply == NULL)
goto out_put_orig; goto out_put_orig;
/* original direction, PNS->PAC */ /* original direction, PNS->PAC */
dir = IP_CT_DIR_ORIGINAL; dir = IP_CT_DIR_ORIGINAL;
nf_conntrack_expect_init(exp_orig, ct->tuplehash[dir].tuple.src.l3num, nf_ct_expect_init(exp_orig, ct->tuplehash[dir].tuple.src.l3num,
&ct->tuplehash[dir].tuple.src.u3, &ct->tuplehash[dir].tuple.src.u3,
&ct->tuplehash[dir].tuple.dst.u3, &ct->tuplehash[dir].tuple.dst.u3,
IPPROTO_GRE, &peer_callid, &callid); IPPROTO_GRE, &peer_callid, &callid);
exp_orig->expectfn = pptp_expectfn; exp_orig->expectfn = pptp_expectfn;
/* reply direction, PAC->PNS */ /* reply direction, PAC->PNS */
dir = IP_CT_DIR_REPLY; dir = IP_CT_DIR_REPLY;
nf_conntrack_expect_init(exp_reply, ct->tuplehash[dir].tuple.src.l3num, nf_ct_expect_init(exp_reply, ct->tuplehash[dir].tuple.src.l3num,
&ct->tuplehash[dir].tuple.src.u3, &ct->tuplehash[dir].tuple.src.u3,
&ct->tuplehash[dir].tuple.dst.u3, &ct->tuplehash[dir].tuple.dst.u3,
IPPROTO_GRE, &callid, &peer_callid); IPPROTO_GRE, &callid, &peer_callid);
exp_reply->expectfn = pptp_expectfn; exp_reply->expectfn = pptp_expectfn;
nf_nat_pptp_exp_gre = rcu_dereference(nf_nat_pptp_hook_exp_gre); nf_nat_pptp_exp_gre = rcu_dereference(nf_nat_pptp_hook_exp_gre);
if (nf_nat_pptp_exp_gre && ct->status & IPS_NAT_MASK) if (nf_nat_pptp_exp_gre && ct->status & IPS_NAT_MASK)
nf_nat_pptp_exp_gre(exp_orig, exp_reply); nf_nat_pptp_exp_gre(exp_orig, exp_reply);
if (nf_conntrack_expect_related(exp_orig) != 0) if (nf_ct_expect_related(exp_orig) != 0)
goto out_put_both; goto out_put_both;
if (nf_conntrack_expect_related(exp_reply) != 0) if (nf_ct_expect_related(exp_reply) != 0)
goto out_unexpect_orig; goto out_unexpect_orig;
/* Add GRE keymap entries */ /* Add GRE keymap entries */
@ -243,16 +243,16 @@ static int exp_gre(struct nf_conn *ct, __be16 callid, __be16 peer_callid)
ret = 0; ret = 0;
out_put_both: out_put_both:
nf_conntrack_expect_put(exp_reply); nf_ct_expect_put(exp_reply);
out_put_orig: out_put_orig:
nf_conntrack_expect_put(exp_orig); nf_ct_expect_put(exp_orig);
out: out:
return ret; return ret;
out_unexpect_both: out_unexpect_both:
nf_conntrack_unexpect_related(exp_reply); nf_ct_unexpect_related(exp_reply);
out_unexpect_orig: out_unexpect_orig:
nf_conntrack_unexpect_related(exp_orig); nf_ct_unexpect_related(exp_orig);
goto out_put_both; goto out_put_both;
} }

View File

@ -141,27 +141,25 @@ static int help(struct sk_buff **pskb,
if (reply->zero != 0) if (reply->zero != 0)
goto out; goto out;
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) { if (exp == NULL) {
ret = NF_DROP; ret = NF_DROP;
goto out; goto out;
} }
tuple = &ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple; tuple = &ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple;
nf_conntrack_expect_init(exp, family, nf_ct_expect_init(exp, family, &tuple->src.u3, &tuple->dst.u3,
&tuple->src.u3, &tuple->dst.u3, IPPROTO_TCP, NULL, &reply->port);
IPPROTO_TCP,
NULL, &reply->port);
DEBUGP("nf_ct_sane: expect: "); DEBUGP("nf_ct_sane: expect: ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
NF_CT_DUMP_TUPLE(&exp->mask); NF_CT_DUMP_TUPLE(&exp->mask);
/* Can't expect this? Best to drop packet now. */ /* Can't expect this? Best to drop packet now. */
if (nf_conntrack_expect_related(exp) != 0) if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
out: out:
spin_unlock_bh(&nf_sane_lock); spin_unlock_bh(&nf_sane_lock);

View File

@ -378,23 +378,23 @@ static int set_expected_rtp(struct sk_buff **pskb,
int ret; int ret;
typeof(nf_nat_sdp_hook) nf_nat_sdp; typeof(nf_nat_sdp_hook) nf_nat_sdp;
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) if (exp == NULL)
return NF_DROP; return NF_DROP;
nf_conntrack_expect_init(exp, family, nf_ct_expect_init(exp, family,
&ct->tuplehash[!dir].tuple.src.u3, addr, &ct->tuplehash[!dir].tuple.src.u3, addr,
IPPROTO_UDP, NULL, &port); IPPROTO_UDP, NULL, &port);
nf_nat_sdp = rcu_dereference(nf_nat_sdp_hook); nf_nat_sdp = rcu_dereference(nf_nat_sdp_hook);
if (nf_nat_sdp && ct->status & IPS_NAT_MASK) if (nf_nat_sdp && ct->status & IPS_NAT_MASK)
ret = nf_nat_sdp(pskb, ctinfo, exp, dptr); ret = nf_nat_sdp(pskb, ctinfo, exp, dptr);
else { else {
if (nf_conntrack_expect_related(exp) != 0) if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
else else
ret = NF_ACCEPT; ret = NF_ACCEPT;
} }
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
return ret; return ret;
} }

View File

@ -66,14 +66,12 @@ static int tftp_help(struct sk_buff **pskb,
NF_CT_DUMP_TUPLE(&ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple); NF_CT_DUMP_TUPLE(&ct->tuplehash[IP_CT_DIR_ORIGINAL].tuple);
NF_CT_DUMP_TUPLE(&ct->tuplehash[IP_CT_DIR_REPLY].tuple); NF_CT_DUMP_TUPLE(&ct->tuplehash[IP_CT_DIR_REPLY].tuple);
exp = nf_conntrack_expect_alloc(ct); exp = nf_ct_expect_alloc(ct);
if (exp == NULL) if (exp == NULL)
return NF_DROP; return NF_DROP;
tuple = &ct->tuplehash[IP_CT_DIR_REPLY].tuple; tuple = &ct->tuplehash[IP_CT_DIR_REPLY].tuple;
nf_conntrack_expect_init(exp, family, nf_ct_expect_init(exp, family, &tuple->src.u3, &tuple->dst.u3,
&tuple->src.u3, &tuple->dst.u3, IPPROTO_UDP, NULL, &tuple->dst.u.udp.port);
IPPROTO_UDP,
NULL, &tuple->dst.u.udp.port);
DEBUGP("expect: "); DEBUGP("expect: ");
NF_CT_DUMP_TUPLE(&exp->tuple); NF_CT_DUMP_TUPLE(&exp->tuple);
@ -82,9 +80,9 @@ static int tftp_help(struct sk_buff **pskb,
nf_nat_tftp = rcu_dereference(nf_nat_tftp_hook); nf_nat_tftp = rcu_dereference(nf_nat_tftp_hook);
if (nf_nat_tftp && ct->status & IPS_NAT_MASK) if (nf_nat_tftp && ct->status & IPS_NAT_MASK)
ret = nf_nat_tftp(pskb, ctinfo, exp); ret = nf_nat_tftp(pskb, ctinfo, exp);
else if (nf_conntrack_expect_related(exp) != 0) else if (nf_ct_expect_related(exp) != 0)
ret = NF_DROP; ret = NF_DROP;
nf_conntrack_expect_put(exp); nf_ct_expect_put(exp);
break; break;
case TFTP_OPCODE_DATA: case TFTP_OPCODE_DATA:
case TFTP_OPCODE_ACK: case TFTP_OPCODE_ACK: