diff options
author | Pablo Neira Ayuso <pablo@netfilter.org> | 2012-06-07 06:11:50 -0400 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2012-06-16 09:08:55 -0400 |
commit | 1afc56794e03229fa53cfa3c5012704d226e1dec (patch) | |
tree | e4182f8c9539d16d96136ca681ab1cf4a8c430ec /net/ipv4 | |
parent | 3cf4c7e381d9a98a44fd86207b950bd8fef55d20 (diff) |
netfilter: nf_ct_helper: implement variable length helper private data
This patch uses the new variable length conntrack extensions.
Instead of using union nf_conntrack_help that contain all the
helper private data information, we allocate variable length
area to store the private helper data.
This patch includes the modification of all existing helpers.
It also includes a couple of include header to avoid compilation
warnings.
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'net/ipv4')
-rw-r--r-- | net/ipv4/netfilter/nf_nat_amanda.c | 4 | ||||
-rw-r--r-- | net/ipv4/netfilter/nf_nat_h323.c | 8 | ||||
-rw-r--r-- | net/ipv4/netfilter/nf_nat_pptp.c | 6 | ||||
-rw-r--r-- | net/ipv4/netfilter/nf_nat_tftp.c | 4 |
4 files changed, 11 insertions, 11 deletions
diff --git a/net/ipv4/netfilter/nf_nat_amanda.c b/net/ipv4/netfilter/nf_nat_amanda.c index 7b22382ff0e9..3c04d24e2976 100644 --- a/net/ipv4/netfilter/nf_nat_amanda.c +++ b/net/ipv4/netfilter/nf_nat_amanda.c | |||
@@ -13,10 +13,10 @@ | |||
13 | #include <linux/skbuff.h> | 13 | #include <linux/skbuff.h> |
14 | #include <linux/udp.h> | 14 | #include <linux/udp.h> |
15 | 15 | ||
16 | #include <net/netfilter/nf_nat_helper.h> | ||
17 | #include <net/netfilter/nf_nat_rule.h> | ||
18 | #include <net/netfilter/nf_conntrack_helper.h> | 16 | #include <net/netfilter/nf_conntrack_helper.h> |
19 | #include <net/netfilter/nf_conntrack_expect.h> | 17 | #include <net/netfilter/nf_conntrack_expect.h> |
18 | #include <net/netfilter/nf_nat_helper.h> | ||
19 | #include <net/netfilter/nf_nat_rule.h> | ||
20 | #include <linux/netfilter/nf_conntrack_amanda.h> | 20 | #include <linux/netfilter/nf_conntrack_amanda.h> |
21 | 21 | ||
22 | MODULE_AUTHOR("Brian J. Murrell <netfilter@interlinx.bc.ca>"); | 22 | MODULE_AUTHOR("Brian J. Murrell <netfilter@interlinx.bc.ca>"); |
diff --git a/net/ipv4/netfilter/nf_nat_h323.c b/net/ipv4/netfilter/nf_nat_h323.c index cad29c121318..c6784a18c1c4 100644 --- a/net/ipv4/netfilter/nf_nat_h323.c +++ b/net/ipv4/netfilter/nf_nat_h323.c | |||
@@ -95,7 +95,7 @@ static int set_sig_addr(struct sk_buff *skb, struct nf_conn *ct, | |||
95 | unsigned char **data, | 95 | unsigned char **data, |
96 | TransportAddress *taddr, int count) | 96 | TransportAddress *taddr, int count) |
97 | { | 97 | { |
98 | const struct nf_ct_h323_master *info = &nfct_help(ct)->help.ct_h323_info; | 98 | const struct nf_ct_h323_master *info = nfct_help_data(ct); |
99 | int dir = CTINFO2DIR(ctinfo); | 99 | int dir = CTINFO2DIR(ctinfo); |
100 | int i; | 100 | int i; |
101 | __be16 port; | 101 | __be16 port; |
@@ -178,7 +178,7 @@ static int nat_rtp_rtcp(struct sk_buff *skb, struct nf_conn *ct, | |||
178 | struct nf_conntrack_expect *rtp_exp, | 178 | struct nf_conntrack_expect *rtp_exp, |
179 | struct nf_conntrack_expect *rtcp_exp) | 179 | struct nf_conntrack_expect *rtcp_exp) |
180 | { | 180 | { |
181 | struct nf_ct_h323_master *info = &nfct_help(ct)->help.ct_h323_info; | 181 | struct nf_ct_h323_master *info = nfct_help_data(ct); |
182 | int dir = CTINFO2DIR(ctinfo); | 182 | int dir = CTINFO2DIR(ctinfo); |
183 | int i; | 183 | int i; |
184 | u_int16_t nated_port; | 184 | u_int16_t nated_port; |
@@ -330,7 +330,7 @@ static int nat_h245(struct sk_buff *skb, struct nf_conn *ct, | |||
330 | TransportAddress *taddr, __be16 port, | 330 | TransportAddress *taddr, __be16 port, |
331 | struct nf_conntrack_expect *exp) | 331 | struct nf_conntrack_expect *exp) |
332 | { | 332 | { |
333 | struct nf_ct_h323_master *info = &nfct_help(ct)->help.ct_h323_info; | 333 | struct nf_ct_h323_master *info = nfct_help_data(ct); |
334 | int dir = CTINFO2DIR(ctinfo); | 334 | int dir = CTINFO2DIR(ctinfo); |
335 | u_int16_t nated_port = ntohs(port); | 335 | u_int16_t nated_port = ntohs(port); |
336 | 336 | ||
@@ -419,7 +419,7 @@ static int nat_q931(struct sk_buff *skb, struct nf_conn *ct, | |||
419 | unsigned char **data, TransportAddress *taddr, int idx, | 419 | unsigned char **data, TransportAddress *taddr, int idx, |
420 | __be16 port, struct nf_conntrack_expect *exp) | 420 | __be16 port, struct nf_conntrack_expect *exp) |
421 | { | 421 | { |
422 | struct nf_ct_h323_master *info = &nfct_help(ct)->help.ct_h323_info; | 422 | struct nf_ct_h323_master *info = nfct_help_data(ct); |
423 | int dir = CTINFO2DIR(ctinfo); | 423 | int dir = CTINFO2DIR(ctinfo); |
424 | u_int16_t nated_port = ntohs(port); | 424 | u_int16_t nated_port = ntohs(port); |
425 | union nf_inet_addr addr; | 425 | union nf_inet_addr addr; |
diff --git a/net/ipv4/netfilter/nf_nat_pptp.c b/net/ipv4/netfilter/nf_nat_pptp.c index c273d58980ae..388140881ebe 100644 --- a/net/ipv4/netfilter/nf_nat_pptp.c +++ b/net/ipv4/netfilter/nf_nat_pptp.c | |||
@@ -49,7 +49,7 @@ static void pptp_nat_expected(struct nf_conn *ct, | |||
49 | const struct nf_nat_pptp *nat_pptp_info; | 49 | const struct nf_nat_pptp *nat_pptp_info; |
50 | struct nf_nat_ipv4_range range; | 50 | struct nf_nat_ipv4_range range; |
51 | 51 | ||
52 | ct_pptp_info = &nfct_help(master)->help.ct_pptp_info; | 52 | ct_pptp_info = nfct_help_data(master); |
53 | nat_pptp_info = &nfct_nat(master)->help.nat_pptp_info; | 53 | nat_pptp_info = &nfct_nat(master)->help.nat_pptp_info; |
54 | 54 | ||
55 | /* And here goes the grand finale of corrosion... */ | 55 | /* And here goes the grand finale of corrosion... */ |
@@ -123,7 +123,7 @@ pptp_outbound_pkt(struct sk_buff *skb, | |||
123 | __be16 new_callid; | 123 | __be16 new_callid; |
124 | unsigned int cid_off; | 124 | unsigned int cid_off; |
125 | 125 | ||
126 | ct_pptp_info = &nfct_help(ct)->help.ct_pptp_info; | 126 | ct_pptp_info = nfct_help_data(ct); |
127 | nat_pptp_info = &nfct_nat(ct)->help.nat_pptp_info; | 127 | nat_pptp_info = &nfct_nat(ct)->help.nat_pptp_info; |
128 | 128 | ||
129 | new_callid = ct_pptp_info->pns_call_id; | 129 | new_callid = ct_pptp_info->pns_call_id; |
@@ -192,7 +192,7 @@ pptp_exp_gre(struct nf_conntrack_expect *expect_orig, | |||
192 | struct nf_ct_pptp_master *ct_pptp_info; | 192 | struct nf_ct_pptp_master *ct_pptp_info; |
193 | struct nf_nat_pptp *nat_pptp_info; | 193 | struct nf_nat_pptp *nat_pptp_info; |
194 | 194 | ||
195 | ct_pptp_info = &nfct_help(ct)->help.ct_pptp_info; | 195 | ct_pptp_info = nfct_help_data(ct); |
196 | nat_pptp_info = &nfct_nat(ct)->help.nat_pptp_info; | 196 | nat_pptp_info = &nfct_nat(ct)->help.nat_pptp_info; |
197 | 197 | ||
198 | /* save original PAC call ID in nat_info */ | 198 | /* save original PAC call ID in nat_info */ |
diff --git a/net/ipv4/netfilter/nf_nat_tftp.c b/net/ipv4/netfilter/nf_nat_tftp.c index a2901bf829c0..9dbb8d284f99 100644 --- a/net/ipv4/netfilter/nf_nat_tftp.c +++ b/net/ipv4/netfilter/nf_nat_tftp.c | |||
@@ -8,10 +8,10 @@ | |||
8 | #include <linux/module.h> | 8 | #include <linux/module.h> |
9 | #include <linux/udp.h> | 9 | #include <linux/udp.h> |
10 | 10 | ||
11 | #include <net/netfilter/nf_nat_helper.h> | ||
12 | #include <net/netfilter/nf_nat_rule.h> | ||
13 | #include <net/netfilter/nf_conntrack_helper.h> | 11 | #include <net/netfilter/nf_conntrack_helper.h> |
14 | #include <net/netfilter/nf_conntrack_expect.h> | 12 | #include <net/netfilter/nf_conntrack_expect.h> |
13 | #include <net/netfilter/nf_nat_helper.h> | ||
14 | #include <net/netfilter/nf_nat_rule.h> | ||
15 | #include <linux/netfilter/nf_conntrack_tftp.h> | 15 | #include <linux/netfilter/nf_conntrack_tftp.h> |
16 | 16 | ||
17 | MODULE_AUTHOR("Magnus Boden <mb@ozaba.mine.nu>"); | 17 | MODULE_AUTHOR("Magnus Boden <mb@ozaba.mine.nu>"); |