diff options
author | Neal Cardwell <ncardwell@google.com> | 2012-06-28 08:34:19 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-06-28 20:53:50 -0400 |
commit | 3840a06e6046aaee95f33a120499d2dc8c054b9d (patch) | |
tree | 6a6acc85ad10729f25b4f3ac81f46facf03b978d /net/ipv6/tcp_ipv6.c | |
parent | 9247869ee661b046510c19a36cf0d91d9c2639d3 (diff) |
tcp: pass fl6 to inet6_csk_route_req()
This commit changes inet_csk_route_req() so that it uses a pointer to
a struct flowi6, rather than allocating its own on the stack. This
brings its behavior in line with its IPv4 cousin,
inet_csk_route_req(), and allows a follow-on patch to fix a dst leak.
Signed-off-by: Neal Cardwell <ncardwell@google.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv6/tcp_ipv6.c')
-rw-r--r-- | net/ipv6/tcp_ipv6.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index fc0b96bf9051..4e5fa5f6ec68 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
@@ -477,7 +477,8 @@ out: | |||
477 | } | 477 | } |
478 | 478 | ||
479 | 479 | ||
480 | static int tcp_v6_send_synack(struct sock *sk, struct request_sock *req, | 480 | static int tcp_v6_send_synack(struct sock *sk, |
481 | struct request_sock *req, | ||
481 | struct request_values *rvp, | 482 | struct request_values *rvp, |
482 | u16 queue_mapping) | 483 | u16 queue_mapping) |
483 | { | 484 | { |
@@ -1058,6 +1059,7 @@ static int tcp_v6_conn_request(struct sock *sk, struct sk_buff *skb) | |||
1058 | struct tcp_sock *tp = tcp_sk(sk); | 1059 | struct tcp_sock *tp = tcp_sk(sk); |
1059 | __u32 isn = TCP_SKB_CB(skb)->when; | 1060 | __u32 isn = TCP_SKB_CB(skb)->when; |
1060 | struct dst_entry *dst = NULL; | 1061 | struct dst_entry *dst = NULL; |
1062 | struct flowi6 fl6; | ||
1061 | bool want_cookie = false; | 1063 | bool want_cookie = false; |
1062 | 1064 | ||
1063 | if (skb->protocol == htons(ETH_P_IP)) | 1065 | if (skb->protocol == htons(ETH_P_IP)) |
@@ -1177,7 +1179,7 @@ static int tcp_v6_conn_request(struct sock *sk, struct sk_buff *skb) | |||
1177 | */ | 1179 | */ |
1178 | if (tmp_opt.saw_tstamp && | 1180 | if (tmp_opt.saw_tstamp && |
1179 | tcp_death_row.sysctl_tw_recycle && | 1181 | tcp_death_row.sysctl_tw_recycle && |
1180 | (dst = inet6_csk_route_req(sk, req)) != NULL && | 1182 | (dst = inet6_csk_route_req(sk, &fl6, req)) != NULL && |
1181 | (peer = rt6_get_peer((struct rt6_info *)dst)) != NULL && | 1183 | (peer = rt6_get_peer((struct rt6_info *)dst)) != NULL && |
1182 | ipv6_addr_equal((struct in6_addr *)peer->daddr.addr.a6, | 1184 | ipv6_addr_equal((struct in6_addr *)peer->daddr.addr.a6, |
1183 | &treq->rmt_addr)) { | 1185 | &treq->rmt_addr)) { |
@@ -1247,6 +1249,7 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
1247 | #ifdef CONFIG_TCP_MD5SIG | 1249 | #ifdef CONFIG_TCP_MD5SIG |
1248 | struct tcp_md5sig_key *key; | 1250 | struct tcp_md5sig_key *key; |
1249 | #endif | 1251 | #endif |
1252 | struct flowi6 fl6; | ||
1250 | 1253 | ||
1251 | if (skb->protocol == htons(ETH_P_IP)) { | 1254 | if (skb->protocol == htons(ETH_P_IP)) { |
1252 | /* | 1255 | /* |
@@ -1309,7 +1312,7 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
1309 | goto out_overflow; | 1312 | goto out_overflow; |
1310 | 1313 | ||
1311 | if (!dst) { | 1314 | if (!dst) { |
1312 | dst = inet6_csk_route_req(sk, req); | 1315 | dst = inet6_csk_route_req(sk, &fl6, req); |
1313 | if (!dst) | 1316 | if (!dst) |
1314 | goto out; | 1317 | goto out; |
1315 | } | 1318 | } |