aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv6/tcp_ipv6.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv6/tcp_ipv6.c')
-rw-r--r--net/ipv6/tcp_ipv6.c75
1 files changed, 36 insertions, 39 deletions
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c
index 80a52ab1e384..85b3e89110f9 100644
--- a/net/ipv6/tcp_ipv6.c
+++ b/net/ipv6/tcp_ipv6.c
@@ -115,8 +115,8 @@ static __inline__ __sum16 tcp_v6_check(struct tcphdr *th, int len,
115 115
116static __u32 tcp_v6_init_sequence(struct sk_buff *skb) 116static __u32 tcp_v6_init_sequence(struct sk_buff *skb)
117{ 117{
118 return secure_tcpv6_sequence_number(skb->nh.ipv6h->daddr.s6_addr32, 118 return secure_tcpv6_sequence_number(ipv6_hdr(skb)->daddr.s6_addr32,
119 skb->nh.ipv6h->saddr.s6_addr32, 119 ipv6_hdr(skb)->saddr.s6_addr32,
120 skb->h.th->dest, 120 skb->h.th->dest,
121 skb->h.th->source); 121 skb->h.th->source);
122} 122}
@@ -837,7 +837,7 @@ static int tcp_v6_inbound_md5_hash (struct sock *sk, struct sk_buff *skb)
837{ 837{
838 __u8 *hash_location = NULL; 838 __u8 *hash_location = NULL;
839 struct tcp_md5sig_key *hash_expected; 839 struct tcp_md5sig_key *hash_expected;
840 struct ipv6hdr *ip6h = skb->nh.ipv6h; 840 struct ipv6hdr *ip6h = ipv6_hdr(skb);
841 struct tcphdr *th = skb->h.th; 841 struct tcphdr *th = skb->h.th;
842 int length = (th->doff << 2) - sizeof (*th); 842 int length = (th->doff << 2) - sizeof (*th);
843 int genhash; 843 int genhash;
@@ -966,7 +966,7 @@ static int tcp_v6_gso_send_check(struct sk_buff *skb)
966 if (!pskb_may_pull(skb, sizeof(*th))) 966 if (!pskb_may_pull(skb, sizeof(*th)))
967 return -EINVAL; 967 return -EINVAL;
968 968
969 ipv6h = skb->nh.ipv6h; 969 ipv6h = ipv6_hdr(skb);
970 th = skb->h.th; 970 th = skb->h.th;
971 971
972 th->check = 0; 972 th->check = 0;
@@ -995,7 +995,7 @@ static void tcp_v6_send_reset(struct sock *sk, struct sk_buff *skb)
995 995
996#ifdef CONFIG_TCP_MD5SIG 996#ifdef CONFIG_TCP_MD5SIG
997 if (sk) 997 if (sk)
998 key = tcp_v6_md5_do_lookup(sk, &skb->nh.ipv6h->daddr); 998 key = tcp_v6_md5_do_lookup(sk, &ipv6_hdr(skb)->daddr);
999 else 999 else
1000 key = NULL; 1000 key = NULL;
1001 1001
@@ -1039,20 +1039,18 @@ static void tcp_v6_send_reset(struct sock *sk, struct sk_buff *skb)
1039 (TCPOPT_NOP << 16) | 1039 (TCPOPT_NOP << 16) |
1040 (TCPOPT_MD5SIG << 8) | 1040 (TCPOPT_MD5SIG << 8) |
1041 TCPOLEN_MD5SIG); 1041 TCPOLEN_MD5SIG);
1042 tcp_v6_do_calc_md5_hash((__u8*)&opt[1], 1042 tcp_v6_do_calc_md5_hash((__u8 *)&opt[1], key,
1043 key, 1043 &ipv6_hdr(skb)->daddr,
1044 &skb->nh.ipv6h->daddr, 1044 &ipv6_hdr(skb)->saddr,
1045 &skb->nh.ipv6h->saddr, 1045 t1, IPPROTO_TCP, tot_len);
1046 t1, IPPROTO_TCP,
1047 tot_len);
1048 } 1046 }
1049#endif 1047#endif
1050 1048
1051 buff->csum = csum_partial((char *)t1, sizeof(*t1), 0); 1049 buff->csum = csum_partial((char *)t1, sizeof(*t1), 0);
1052 1050
1053 memset(&fl, 0, sizeof(fl)); 1051 memset(&fl, 0, sizeof(fl));
1054 ipv6_addr_copy(&fl.fl6_dst, &skb->nh.ipv6h->saddr); 1052 ipv6_addr_copy(&fl.fl6_dst, &ipv6_hdr(skb)->saddr);
1055 ipv6_addr_copy(&fl.fl6_src, &skb->nh.ipv6h->daddr); 1053 ipv6_addr_copy(&fl.fl6_src, &ipv6_hdr(skb)->daddr);
1056 1054
1057 t1->check = csum_ipv6_magic(&fl.fl6_src, &fl.fl6_dst, 1055 t1->check = csum_ipv6_magic(&fl.fl6_src, &fl.fl6_dst,
1058 sizeof(*t1), IPPROTO_TCP, 1056 sizeof(*t1), IPPROTO_TCP,
@@ -1093,7 +1091,7 @@ static void tcp_v6_send_ack(struct tcp_timewait_sock *tw,
1093 1091
1094#ifdef CONFIG_TCP_MD5SIG 1092#ifdef CONFIG_TCP_MD5SIG
1095 if (!tw && skb->sk) { 1093 if (!tw && skb->sk) {
1096 key = tcp_v6_md5_do_lookup(skb->sk, &skb->nh.ipv6h->daddr); 1094 key = tcp_v6_md5_do_lookup(skb->sk, &ipv6_hdr(skb)->daddr);
1097 } else if (tw && tw->tw_md5_keylen) { 1095 } else if (tw && tw->tw_md5_keylen) {
1098 tw_key.key = tw->tw_md5_key; 1096 tw_key.key = tw->tw_md5_key;
1099 tw_key.keylen = tw->tw_md5_keylen; 1097 tw_key.keylen = tw->tw_md5_keylen;
@@ -1142,20 +1140,18 @@ static void tcp_v6_send_ack(struct tcp_timewait_sock *tw,
1142 if (key) { 1140 if (key) {
1143 *topt++ = htonl((TCPOPT_NOP << 24) | (TCPOPT_NOP << 16) | 1141 *topt++ = htonl((TCPOPT_NOP << 24) | (TCPOPT_NOP << 16) |
1144 (TCPOPT_MD5SIG << 8) | TCPOLEN_MD5SIG); 1142 (TCPOPT_MD5SIG << 8) | TCPOLEN_MD5SIG);
1145 tcp_v6_do_calc_md5_hash((__u8 *)topt, 1143 tcp_v6_do_calc_md5_hash((__u8 *)topt, key,
1146 key, 1144 &ipv6_hdr(skb)->daddr,
1147 &skb->nh.ipv6h->daddr, 1145 &ipv6_hdr(skb)->saddr,
1148 &skb->nh.ipv6h->saddr, 1146 t1, IPPROTO_TCP, tot_len);
1149 t1, IPPROTO_TCP,
1150 tot_len);
1151 } 1147 }
1152#endif 1148#endif
1153 1149
1154 buff->csum = csum_partial((char *)t1, tot_len, 0); 1150 buff->csum = csum_partial((char *)t1, tot_len, 0);
1155 1151
1156 memset(&fl, 0, sizeof(fl)); 1152 memset(&fl, 0, sizeof(fl));
1157 ipv6_addr_copy(&fl.fl6_dst, &skb->nh.ipv6h->saddr); 1153 ipv6_addr_copy(&fl.fl6_dst, &ipv6_hdr(skb)->saddr);
1158 ipv6_addr_copy(&fl.fl6_src, &skb->nh.ipv6h->daddr); 1154 ipv6_addr_copy(&fl.fl6_src, &ipv6_hdr(skb)->daddr);
1159 1155
1160 t1->check = csum_ipv6_magic(&fl.fl6_src, &fl.fl6_dst, 1156 t1->check = csum_ipv6_magic(&fl.fl6_src, &fl.fl6_dst,
1161 tot_len, IPPROTO_TCP, 1157 tot_len, IPPROTO_TCP,
@@ -1204,13 +1200,13 @@ static struct sock *tcp_v6_hnd_req(struct sock *sk,struct sk_buff *skb)
1204 1200
1205 /* Find possible connection requests. */ 1201 /* Find possible connection requests. */
1206 req = inet6_csk_search_req(sk, &prev, th->source, 1202 req = inet6_csk_search_req(sk, &prev, th->source,
1207 &skb->nh.ipv6h->saddr, 1203 &ipv6_hdr(skb)->saddr,
1208 &skb->nh.ipv6h->daddr, inet6_iif(skb)); 1204 &ipv6_hdr(skb)->daddr, inet6_iif(skb));
1209 if (req) 1205 if (req)
1210 return tcp_check_req(sk, skb, req, prev); 1206 return tcp_check_req(sk, skb, req, prev);
1211 1207
1212 nsk = __inet6_lookup_established(&tcp_hashinfo, &skb->nh.ipv6h->saddr, 1208 nsk = __inet6_lookup_established(&tcp_hashinfo, &ipv6_hdr(skb)->saddr,
1213 th->source, &skb->nh.ipv6h->daddr, 1209 th->source, &ipv6_hdr(skb)->daddr,
1214 ntohs(th->dest), inet6_iif(skb)); 1210 ntohs(th->dest), inet6_iif(skb));
1215 1211
1216 if (nsk) { 1212 if (nsk) {
@@ -1277,8 +1273,8 @@ static int tcp_v6_conn_request(struct sock *sk, struct sk_buff *skb)
1277 tcp_openreq_init(req, &tmp_opt, skb); 1273 tcp_openreq_init(req, &tmp_opt, skb);
1278 1274
1279 treq = inet6_rsk(req); 1275 treq = inet6_rsk(req);
1280 ipv6_addr_copy(&treq->rmt_addr, &skb->nh.ipv6h->saddr); 1276 ipv6_addr_copy(&treq->rmt_addr, &ipv6_hdr(skb)->saddr);
1281 ipv6_addr_copy(&treq->loc_addr, &skb->nh.ipv6h->daddr); 1277 ipv6_addr_copy(&treq->loc_addr, &ipv6_hdr(skb)->daddr);
1282 TCP_ECN_create_request(req, skb->h.th); 1278 TCP_ECN_create_request(req, skb->h.th);
1283 treq->pktopts = NULL; 1279 treq->pktopts = NULL;
1284 if (ipv6_opt_accepted(sk, skb) || 1280 if (ipv6_opt_accepted(sk, skb) ||
@@ -1365,7 +1361,7 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb,
1365 newnp->pktoptions = NULL; 1361 newnp->pktoptions = NULL;
1366 newnp->opt = NULL; 1362 newnp->opt = NULL;
1367 newnp->mcast_oif = inet6_iif(skb); 1363 newnp->mcast_oif = inet6_iif(skb);
1368 newnp->mcast_hops = skb->nh.ipv6h->hop_limit; 1364 newnp->mcast_hops = ipv6_hdr(skb)->hop_limit;
1369 1365
1370 /* 1366 /*
1371 * No need to charge this sock to the relevant IPv6 refcnt debug socks count 1367 * No need to charge this sock to the relevant IPv6 refcnt debug socks count
@@ -1473,7 +1469,7 @@ static struct sock * tcp_v6_syn_recv_sock(struct sock *sk, struct sk_buff *skb,
1473 } 1469 }
1474 newnp->opt = NULL; 1470 newnp->opt = NULL;
1475 newnp->mcast_oif = inet6_iif(skb); 1471 newnp->mcast_oif = inet6_iif(skb);
1476 newnp->mcast_hops = skb->nh.ipv6h->hop_limit; 1472 newnp->mcast_hops = ipv6_hdr(skb)->hop_limit;
1477 1473
1478 /* Clone native IPv6 options from listening socket (if any) 1474 /* Clone native IPv6 options from listening socket (if any)
1479 1475
@@ -1532,15 +1528,16 @@ out:
1532static __sum16 tcp_v6_checksum_init(struct sk_buff *skb) 1528static __sum16 tcp_v6_checksum_init(struct sk_buff *skb)
1533{ 1529{
1534 if (skb->ip_summed == CHECKSUM_COMPLETE) { 1530 if (skb->ip_summed == CHECKSUM_COMPLETE) {
1535 if (!tcp_v6_check(skb->h.th,skb->len,&skb->nh.ipv6h->saddr, 1531 if (!tcp_v6_check(skb->h.th, skb->len, &ipv6_hdr(skb)->saddr,
1536 &skb->nh.ipv6h->daddr,skb->csum)) { 1532 &ipv6_hdr(skb)->daddr, skb->csum)) {
1537 skb->ip_summed = CHECKSUM_UNNECESSARY; 1533 skb->ip_summed = CHECKSUM_UNNECESSARY;
1538 return 0; 1534 return 0;
1539 } 1535 }
1540 } 1536 }
1541 1537
1542 skb->csum = ~csum_unfold(tcp_v6_check(skb->h.th,skb->len,&skb->nh.ipv6h->saddr, 1538 skb->csum = ~csum_unfold(tcp_v6_check(skb->h.th, skb->len,
1543 &skb->nh.ipv6h->daddr, 0)); 1539 &ipv6_hdr(skb)->saddr,
1540 &ipv6_hdr(skb)->daddr, 0));
1544 1541
1545 if (skb->len <= 76) { 1542 if (skb->len <= 76) {
1546 return __skb_checksum_complete(skb); 1543 return __skb_checksum_complete(skb);
@@ -1668,7 +1665,7 @@ ipv6_pktoptions:
1668 if (np->rxopt.bits.rxinfo || np->rxopt.bits.rxoinfo) 1665 if (np->rxopt.bits.rxinfo || np->rxopt.bits.rxoinfo)
1669 np->mcast_oif = inet6_iif(opt_skb); 1666 np->mcast_oif = inet6_iif(opt_skb);
1670 if (np->rxopt.bits.rxhlim || np->rxopt.bits.rxohlim) 1667 if (np->rxopt.bits.rxhlim || np->rxopt.bits.rxohlim)
1671 np->mcast_hops = opt_skb->nh.ipv6h->hop_limit; 1668 np->mcast_hops = ipv6_hdr(opt_skb)->hop_limit;
1672 if (ipv6_opt_accepted(sk, opt_skb)) { 1669 if (ipv6_opt_accepted(sk, opt_skb)) {
1673 skb_set_owner_r(opt_skb, sk); 1670 skb_set_owner_r(opt_skb, sk);
1674 opt_skb = xchg(&np->pktoptions, opt_skb); 1671 opt_skb = xchg(&np->pktoptions, opt_skb);
@@ -1718,11 +1715,11 @@ static int tcp_v6_rcv(struct sk_buff **pskb)
1718 skb->len - th->doff*4); 1715 skb->len - th->doff*4);
1719 TCP_SKB_CB(skb)->ack_seq = ntohl(th->ack_seq); 1716 TCP_SKB_CB(skb)->ack_seq = ntohl(th->ack_seq);
1720 TCP_SKB_CB(skb)->when = 0; 1717 TCP_SKB_CB(skb)->when = 0;
1721 TCP_SKB_CB(skb)->flags = ipv6_get_dsfield(skb->nh.ipv6h); 1718 TCP_SKB_CB(skb)->flags = ipv6_get_dsfield(ipv6_hdr(skb));
1722 TCP_SKB_CB(skb)->sacked = 0; 1719 TCP_SKB_CB(skb)->sacked = 0;
1723 1720
1724 sk = __inet6_lookup(&tcp_hashinfo, &skb->nh.ipv6h->saddr, th->source, 1721 sk = __inet6_lookup(&tcp_hashinfo, &ipv6_hdr(skb)->saddr, th->source,
1725 &skb->nh.ipv6h->daddr, ntohs(th->dest), 1722 &ipv6_hdr(skb)->daddr, ntohs(th->dest),
1726 inet6_iif(skb)); 1723 inet6_iif(skb));
1727 1724
1728 if (!sk) 1725 if (!sk)
@@ -1802,7 +1799,7 @@ do_time_wait:
1802 struct sock *sk2; 1799 struct sock *sk2;
1803 1800
1804 sk2 = inet6_lookup_listener(&tcp_hashinfo, 1801 sk2 = inet6_lookup_listener(&tcp_hashinfo,
1805 &skb->nh.ipv6h->daddr, 1802 &ipv6_hdr(skb)->daddr,
1806 ntohs(th->dest), inet6_iif(skb)); 1803 ntohs(th->dest), inet6_iif(skb));
1807 if (sk2 != NULL) { 1804 if (sk2 != NULL) {
1808 struct inet_timewait_sock *tw = inet_twsk(sk); 1805 struct inet_timewait_sock *tw = inet_twsk(sk);