diff options
| author | Arnaud Ebalard <arno@natisbad.org> | 2010-06-01 17:35:01 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2010-06-02 10:08:31 -0400 |
| commit | 20c59de2e6b6bc74bbf714dcd4e720afe8d516cf (patch) | |
| tree | 45e5c62e286368f8259b844cb7cf796d19066fb0 /net/ipv6/tcp_ipv6.c | |
| parent | d92222e27fdc98d73df25f3d49fb1ff3a3369bec (diff) | |
ipv6: Refactor update of IPv6 flowi destination address for srcrt (RH) option
There are more than a dozen occurrences of following code in the
IPv6 stack:
if (opt && opt->srcrt) {
struct rt0_hdr *rt0 = (struct rt0_hdr *) opt->srcrt;
ipv6_addr_copy(&final, &fl.fl6_dst);
ipv6_addr_copy(&fl.fl6_dst, rt0->addr);
final_p = &final;
}
Replace those with a helper. Note that the helper overrides final_p
in all cases. This is ok as final_p was previously initialized to
NULL when declared.
Signed-off-by: Arnaud Ebalard <arno@natisbad.org>
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 | 27 |
1 files changed, 6 insertions, 21 deletions
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c index 2b7c3a100e2c..e487080d02db 100644 --- a/net/ipv6/tcp_ipv6.c +++ b/net/ipv6/tcp_ipv6.c | |||
| @@ -129,7 +129,7 @@ static int tcp_v6_connect(struct sock *sk, struct sockaddr *uaddr, | |||
| 129 | struct inet_connection_sock *icsk = inet_csk(sk); | 129 | struct inet_connection_sock *icsk = inet_csk(sk); |
| 130 | struct ipv6_pinfo *np = inet6_sk(sk); | 130 | struct ipv6_pinfo *np = inet6_sk(sk); |
| 131 | struct tcp_sock *tp = tcp_sk(sk); | 131 | struct tcp_sock *tp = tcp_sk(sk); |
| 132 | struct in6_addr *saddr = NULL, *final_p = NULL, final; | 132 | struct in6_addr *saddr = NULL, *final_p, final; |
| 133 | struct flowi fl; | 133 | struct flowi fl; |
| 134 | struct dst_entry *dst; | 134 | struct dst_entry *dst; |
| 135 | int addr_type; | 135 | int addr_type; |
| @@ -250,12 +250,7 @@ static int tcp_v6_connect(struct sock *sk, struct sockaddr *uaddr, | |||
| 250 | fl.fl_ip_dport = usin->sin6_port; | 250 | fl.fl_ip_dport = usin->sin6_port; |
| 251 | fl.fl_ip_sport = inet->inet_sport; | 251 | fl.fl_ip_sport = inet->inet_sport; |
| 252 | 252 | ||
| 253 | if (np->opt && np->opt->srcrt) { | 253 | final_p = fl6_update_dst(&fl, np->opt, &final); |
| 254 | struct rt0_hdr *rt0 = (struct rt0_hdr *)np->opt->srcrt; | ||
| 255 | ipv6_addr_copy(&final, &fl.fl6_dst); | ||
| 256 | ipv6_addr_copy(&fl.fl6_dst, rt0->addr); | ||
| 257 | final_p = &final; | ||
| 258 | } | ||
| 259 | 254 | ||
| 260 | security_sk_classify_flow(sk, &fl); | 255 | security_sk_classify_flow(sk, &fl); |
| 261 | 256 | ||
| @@ -477,7 +472,7 @@ static int tcp_v6_send_synack(struct sock *sk, struct request_sock *req, | |||
| 477 | struct ipv6_pinfo *np = inet6_sk(sk); | 472 | struct ipv6_pinfo *np = inet6_sk(sk); |
| 478 | struct sk_buff * skb; | 473 | struct sk_buff * skb; |
| 479 | struct ipv6_txoptions *opt = NULL; | 474 | struct ipv6_txoptions *opt = NULL; |
| 480 | struct in6_addr * final_p = NULL, final; | 475 | struct in6_addr * final_p, final; |
| 481 | struct flowi fl; | 476 | struct flowi fl; |
| 482 | struct dst_entry *dst; | 477 | struct dst_entry *dst; |
| 483 | int err = -1; | 478 | int err = -1; |
| @@ -494,12 +489,7 @@ static int tcp_v6_send_synack(struct sock *sk, struct request_sock *req, | |||
| 494 | security_req_classify_flow(req, &fl); | 489 | security_req_classify_flow(req, &fl); |
| 495 | 490 | ||
| 496 | opt = np->opt; | 491 | opt = np->opt; |
| 497 | if (opt && opt->srcrt) { | 492 | final_p = fl6_update_dst(&fl, opt, &final); |
| 498 | struct rt0_hdr *rt0 = (struct rt0_hdr *) opt->srcrt; | ||
| 499 | ipv6_addr_copy(&final, &fl.fl6_dst); | ||
| 500 | ipv6_addr_copy(&fl.fl6_dst, rt0->addr); | ||
| 501 | final_p = &final; | ||
| 502 | } | ||
| 503 | 493 | ||
| 504 | err = ip6_dst_lookup(sk, &dst, &fl); | 494 | err = ip6_dst_lookup(sk, &dst, &fl); |
| 505 | if (err) | 495 | if (err) |
| @@ -1392,18 +1382,13 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb, | |||
| 1392 | goto out_overflow; | 1382 | goto out_overflow; |
| 1393 | 1383 | ||
| 1394 | if (dst == NULL) { | 1384 | if (dst == NULL) { |
| 1395 | struct in6_addr *final_p = NULL, final; | 1385 | struct in6_addr *final_p, final; |
| 1396 | struct flowi fl; | 1386 | struct flowi fl; |
| 1397 | 1387 | ||
| 1398 | memset(&fl, 0, sizeof(fl)); | 1388 | memset(&fl, 0, sizeof(fl)); |
| 1399 | fl.proto = IPPROTO_TCP; | 1389 | fl.proto = IPPROTO_TCP; |
| 1400 | ipv6_addr_copy(&fl.fl6_dst, &treq->rmt_addr); | 1390 | ipv6_addr_copy(&fl.fl6_dst, &treq->rmt_addr); |
| 1401 | if (opt && opt->srcrt) { | 1391 | final_p = fl6_update_dst(&fl, opt, &final); |
| 1402 | struct rt0_hdr *rt0 = (struct rt0_hdr *) opt->srcrt; | ||
| 1403 | ipv6_addr_copy(&final, &fl.fl6_dst); | ||
| 1404 | ipv6_addr_copy(&fl.fl6_dst, rt0->addr); | ||
| 1405 | final_p = &final; | ||
| 1406 | } | ||
| 1407 | ipv6_addr_copy(&fl.fl6_src, &treq->loc_addr); | 1392 | ipv6_addr_copy(&fl.fl6_src, &treq->loc_addr); |
| 1408 | fl.oif = sk->sk_bound_dev_if; | 1393 | fl.oif = sk->sk_bound_dev_if; |
| 1409 | fl.mark = sk->sk_mark; | 1394 | fl.mark = sk->sk_mark; |
