Commit 8fef24ca authored by Liping Zhang's avatar Liping Zhang Committed by Pablo Neira Ayuso

netfilter: ip6t_SYNPROXY: remove magic number for hop_limit

Replace '64' with the per-net ipv6_devconf_all's hop_limit when
building the ipv6 header.
Signed-off-by: default avatarLiping Zhang <liping.zhang@spreadtrum.com>
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent 8d45ff22
...@@ -20,7 +20,8 @@ ...@@ -20,7 +20,8 @@
#include <net/netfilter/nf_conntrack_synproxy.h> #include <net/netfilter/nf_conntrack_synproxy.h>
static struct ipv6hdr * static struct ipv6hdr *
synproxy_build_ip(struct sk_buff *skb, const struct in6_addr *saddr, synproxy_build_ip(struct net *net, struct sk_buff *skb,
const struct in6_addr *saddr,
const struct in6_addr *daddr) const struct in6_addr *daddr)
{ {
struct ipv6hdr *iph; struct ipv6hdr *iph;
...@@ -28,7 +29,7 @@ synproxy_build_ip(struct sk_buff *skb, const struct in6_addr *saddr, ...@@ -28,7 +29,7 @@ synproxy_build_ip(struct sk_buff *skb, const struct in6_addr *saddr,
skb_reset_network_header(skb); skb_reset_network_header(skb);
iph = (struct ipv6hdr *)skb_put(skb, sizeof(*iph)); iph = (struct ipv6hdr *)skb_put(skb, sizeof(*iph));
ip6_flow_hdr(iph, 0, 0); ip6_flow_hdr(iph, 0, 0);
iph->hop_limit = 64; //XXX iph->hop_limit = net->ipv6.devconf_all->hop_limit;
iph->nexthdr = IPPROTO_TCP; iph->nexthdr = IPPROTO_TCP;
iph->saddr = *saddr; iph->saddr = *saddr;
iph->daddr = *daddr; iph->daddr = *daddr;
...@@ -37,13 +38,12 @@ synproxy_build_ip(struct sk_buff *skb, const struct in6_addr *saddr, ...@@ -37,13 +38,12 @@ synproxy_build_ip(struct sk_buff *skb, const struct in6_addr *saddr,
} }
static void static void
synproxy_send_tcp(const struct synproxy_net *snet, synproxy_send_tcp(struct net *net,
const struct sk_buff *skb, struct sk_buff *nskb, const struct sk_buff *skb, struct sk_buff *nskb,
struct nf_conntrack *nfct, enum ip_conntrack_info ctinfo, struct nf_conntrack *nfct, enum ip_conntrack_info ctinfo,
struct ipv6hdr *niph, struct tcphdr *nth, struct ipv6hdr *niph, struct tcphdr *nth,
unsigned int tcp_hdr_size) unsigned int tcp_hdr_size)
{ {
struct net *net = nf_ct_net(snet->tmpl);
struct dst_entry *dst; struct dst_entry *dst;
struct flowi6 fl6; struct flowi6 fl6;
...@@ -84,7 +84,7 @@ synproxy_send_tcp(const struct synproxy_net *snet, ...@@ -84,7 +84,7 @@ synproxy_send_tcp(const struct synproxy_net *snet,
} }
static void static void
synproxy_send_client_synack(const struct synproxy_net *snet, synproxy_send_client_synack(struct net *net,
const struct sk_buff *skb, const struct tcphdr *th, const struct sk_buff *skb, const struct tcphdr *th,
const struct synproxy_options *opts) const struct synproxy_options *opts)
{ {
...@@ -103,7 +103,7 @@ synproxy_send_client_synack(const struct synproxy_net *snet, ...@@ -103,7 +103,7 @@ synproxy_send_client_synack(const struct synproxy_net *snet,
return; return;
skb_reserve(nskb, MAX_TCP_HEADER); skb_reserve(nskb, MAX_TCP_HEADER);
niph = synproxy_build_ip(nskb, &iph->daddr, &iph->saddr); niph = synproxy_build_ip(net, nskb, &iph->daddr, &iph->saddr);
skb_reset_transport_header(nskb); skb_reset_transport_header(nskb);
nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size); nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size);
...@@ -121,15 +121,16 @@ synproxy_send_client_synack(const struct synproxy_net *snet, ...@@ -121,15 +121,16 @@ synproxy_send_client_synack(const struct synproxy_net *snet,
synproxy_build_options(nth, opts); synproxy_build_options(nth, opts);
synproxy_send_tcp(snet, skb, nskb, skb->nfct, IP_CT_ESTABLISHED_REPLY, synproxy_send_tcp(net, skb, nskb, skb->nfct, IP_CT_ESTABLISHED_REPLY,
niph, nth, tcp_hdr_size); niph, nth, tcp_hdr_size);
} }
static void static void
synproxy_send_server_syn(const struct synproxy_net *snet, synproxy_send_server_syn(struct net *net,
const struct sk_buff *skb, const struct tcphdr *th, const struct sk_buff *skb, const struct tcphdr *th,
const struct synproxy_options *opts, u32 recv_seq) const struct synproxy_options *opts, u32 recv_seq)
{ {
struct synproxy_net *snet = synproxy_pernet(net);
struct sk_buff *nskb; struct sk_buff *nskb;
struct ipv6hdr *iph, *niph; struct ipv6hdr *iph, *niph;
struct tcphdr *nth; struct tcphdr *nth;
...@@ -144,7 +145,7 @@ synproxy_send_server_syn(const struct synproxy_net *snet, ...@@ -144,7 +145,7 @@ synproxy_send_server_syn(const struct synproxy_net *snet,
return; return;
skb_reserve(nskb, MAX_TCP_HEADER); skb_reserve(nskb, MAX_TCP_HEADER);
niph = synproxy_build_ip(nskb, &iph->saddr, &iph->daddr); niph = synproxy_build_ip(net, nskb, &iph->saddr, &iph->daddr);
skb_reset_transport_header(nskb); skb_reset_transport_header(nskb);
nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size); nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size);
...@@ -165,12 +166,12 @@ synproxy_send_server_syn(const struct synproxy_net *snet, ...@@ -165,12 +166,12 @@ synproxy_send_server_syn(const struct synproxy_net *snet,
synproxy_build_options(nth, opts); synproxy_build_options(nth, opts);
synproxy_send_tcp(snet, skb, nskb, &snet->tmpl->ct_general, IP_CT_NEW, synproxy_send_tcp(net, skb, nskb, &snet->tmpl->ct_general, IP_CT_NEW,
niph, nth, tcp_hdr_size); niph, nth, tcp_hdr_size);
} }
static void static void
synproxy_send_server_ack(const struct synproxy_net *snet, synproxy_send_server_ack(struct net *net,
const struct ip_ct_tcp *state, const struct ip_ct_tcp *state,
const struct sk_buff *skb, const struct tcphdr *th, const struct sk_buff *skb, const struct tcphdr *th,
const struct synproxy_options *opts) const struct synproxy_options *opts)
...@@ -189,7 +190,7 @@ synproxy_send_server_ack(const struct synproxy_net *snet, ...@@ -189,7 +190,7 @@ synproxy_send_server_ack(const struct synproxy_net *snet,
return; return;
skb_reserve(nskb, MAX_TCP_HEADER); skb_reserve(nskb, MAX_TCP_HEADER);
niph = synproxy_build_ip(nskb, &iph->daddr, &iph->saddr); niph = synproxy_build_ip(net, nskb, &iph->daddr, &iph->saddr);
skb_reset_transport_header(nskb); skb_reset_transport_header(nskb);
nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size); nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size);
...@@ -205,11 +206,11 @@ synproxy_send_server_ack(const struct synproxy_net *snet, ...@@ -205,11 +206,11 @@ synproxy_send_server_ack(const struct synproxy_net *snet,
synproxy_build_options(nth, opts); synproxy_build_options(nth, opts);
synproxy_send_tcp(snet, skb, nskb, NULL, 0, niph, nth, tcp_hdr_size); synproxy_send_tcp(net, skb, nskb, NULL, 0, niph, nth, tcp_hdr_size);
} }
static void static void
synproxy_send_client_ack(const struct synproxy_net *snet, synproxy_send_client_ack(struct net *net,
const struct sk_buff *skb, const struct tcphdr *th, const struct sk_buff *skb, const struct tcphdr *th,
const struct synproxy_options *opts) const struct synproxy_options *opts)
{ {
...@@ -227,7 +228,7 @@ synproxy_send_client_ack(const struct synproxy_net *snet, ...@@ -227,7 +228,7 @@ synproxy_send_client_ack(const struct synproxy_net *snet,
return; return;
skb_reserve(nskb, MAX_TCP_HEADER); skb_reserve(nskb, MAX_TCP_HEADER);
niph = synproxy_build_ip(nskb, &iph->saddr, &iph->daddr); niph = synproxy_build_ip(net, nskb, &iph->saddr, &iph->daddr);
skb_reset_transport_header(nskb); skb_reset_transport_header(nskb);
nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size); nth = (struct tcphdr *)skb_put(nskb, tcp_hdr_size);
...@@ -243,15 +244,16 @@ synproxy_send_client_ack(const struct synproxy_net *snet, ...@@ -243,15 +244,16 @@ synproxy_send_client_ack(const struct synproxy_net *snet,
synproxy_build_options(nth, opts); synproxy_build_options(nth, opts);
synproxy_send_tcp(snet, skb, nskb, skb->nfct, IP_CT_ESTABLISHED_REPLY, synproxy_send_tcp(net, skb, nskb, skb->nfct, IP_CT_ESTABLISHED_REPLY,
niph, nth, tcp_hdr_size); niph, nth, tcp_hdr_size);
} }
static bool static bool
synproxy_recv_client_ack(const struct synproxy_net *snet, synproxy_recv_client_ack(struct net *net,
const struct sk_buff *skb, const struct tcphdr *th, const struct sk_buff *skb, const struct tcphdr *th,
struct synproxy_options *opts, u32 recv_seq) struct synproxy_options *opts, u32 recv_seq)
{ {
struct synproxy_net *snet = synproxy_pernet(net);
int mss; int mss;
mss = __cookie_v6_check(ipv6_hdr(skb), th, ntohl(th->ack_seq) - 1); mss = __cookie_v6_check(ipv6_hdr(skb), th, ntohl(th->ack_seq) - 1);
...@@ -267,7 +269,7 @@ synproxy_recv_client_ack(const struct synproxy_net *snet, ...@@ -267,7 +269,7 @@ synproxy_recv_client_ack(const struct synproxy_net *snet,
if (opts->options & XT_SYNPROXY_OPT_TIMESTAMP) if (opts->options & XT_SYNPROXY_OPT_TIMESTAMP)
synproxy_check_timestamp_cookie(opts); synproxy_check_timestamp_cookie(opts);
synproxy_send_server_syn(snet, skb, th, opts, recv_seq); synproxy_send_server_syn(net, skb, th, opts, recv_seq);
return true; return true;
} }
...@@ -275,7 +277,8 @@ static unsigned int ...@@ -275,7 +277,8 @@ static unsigned int
synproxy_tg6(struct sk_buff *skb, const struct xt_action_param *par) synproxy_tg6(struct sk_buff *skb, const struct xt_action_param *par)
{ {
const struct xt_synproxy_info *info = par->targinfo; const struct xt_synproxy_info *info = par->targinfo;
struct synproxy_net *snet = synproxy_pernet(par->net); struct net *net = par->net;
struct synproxy_net *snet = synproxy_pernet(net);
struct synproxy_options opts = {}; struct synproxy_options opts = {};
struct tcphdr *th, _th; struct tcphdr *th, _th;
...@@ -304,12 +307,12 @@ synproxy_tg6(struct sk_buff *skb, const struct xt_action_param *par) ...@@ -304,12 +307,12 @@ synproxy_tg6(struct sk_buff *skb, const struct xt_action_param *par)
XT_SYNPROXY_OPT_SACK_PERM | XT_SYNPROXY_OPT_SACK_PERM |
XT_SYNPROXY_OPT_ECN); XT_SYNPROXY_OPT_ECN);
synproxy_send_client_synack(snet, skb, th, &opts); synproxy_send_client_synack(net, skb, th, &opts);
return NF_DROP; return NF_DROP;
} else if (th->ack && !(th->fin || th->rst || th->syn)) { } else if (th->ack && !(th->fin || th->rst || th->syn)) {
/* ACK from client */ /* ACK from client */
synproxy_recv_client_ack(snet, skb, th, &opts, ntohl(th->seq)); synproxy_recv_client_ack(net, skb, th, &opts, ntohl(th->seq));
return NF_DROP; return NF_DROP;
} }
...@@ -320,7 +323,8 @@ static unsigned int ipv6_synproxy_hook(void *priv, ...@@ -320,7 +323,8 @@ static unsigned int ipv6_synproxy_hook(void *priv,
struct sk_buff *skb, struct sk_buff *skb,
const struct nf_hook_state *nhs) const struct nf_hook_state *nhs)
{ {
struct synproxy_net *snet = synproxy_pernet(nhs->net); struct net *net = nhs->net;
struct synproxy_net *snet = synproxy_pernet(net);
enum ip_conntrack_info ctinfo; enum ip_conntrack_info ctinfo;
struct nf_conn *ct; struct nf_conn *ct;
struct nf_conn_synproxy *synproxy; struct nf_conn_synproxy *synproxy;
...@@ -384,7 +388,7 @@ static unsigned int ipv6_synproxy_hook(void *priv, ...@@ -384,7 +388,7 @@ static unsigned int ipv6_synproxy_hook(void *priv,
* therefore we need to add 1 to make the SYN sequence * therefore we need to add 1 to make the SYN sequence
* number match the one of first SYN. * number match the one of first SYN.
*/ */
if (synproxy_recv_client_ack(snet, skb, th, &opts, if (synproxy_recv_client_ack(net, skb, th, &opts,
ntohl(th->seq) + 1)) ntohl(th->seq) + 1))
this_cpu_inc(snet->stats->cookie_retrans); this_cpu_inc(snet->stats->cookie_retrans);
...@@ -410,12 +414,12 @@ static unsigned int ipv6_synproxy_hook(void *priv, ...@@ -410,12 +414,12 @@ static unsigned int ipv6_synproxy_hook(void *priv,
XT_SYNPROXY_OPT_SACK_PERM); XT_SYNPROXY_OPT_SACK_PERM);
swap(opts.tsval, opts.tsecr); swap(opts.tsval, opts.tsecr);
synproxy_send_server_ack(snet, state, skb, th, &opts); synproxy_send_server_ack(net, state, skb, th, &opts);
nf_ct_seqadj_init(ct, ctinfo, synproxy->isn - ntohl(th->seq)); nf_ct_seqadj_init(ct, ctinfo, synproxy->isn - ntohl(th->seq));
swap(opts.tsval, opts.tsecr); swap(opts.tsval, opts.tsecr);
synproxy_send_client_ack(snet, skb, th, &opts); synproxy_send_client_ack(net, skb, th, &opts);
consume_skb(skb); consume_skb(skb);
return NF_STOLEN; return NF_STOLEN;
......
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