diff options
| -rw-r--r-- | net/ipv6/ip6_output.c | 3 | ||||
| -rw-r--r-- | net/ipv6/raw.c | 1 |
2 files changed, 4 insertions, 0 deletions
diff --git a/net/ipv6/ip6_output.c b/net/ipv6/ip6_output.c index 6e3ddf806ec2..e7ceb6c871d1 100644 --- a/net/ipv6/ip6_output.c +++ b/net/ipv6/ip6_output.c | |||
| @@ -238,6 +238,7 @@ int ip6_xmit(struct sock *sk, struct sk_buff *skb, struct flowi6 *fl6, | |||
| 238 | hdr->saddr = fl6->saddr; | 238 | hdr->saddr = fl6->saddr; |
| 239 | hdr->daddr = *first_hop; | 239 | hdr->daddr = *first_hop; |
| 240 | 240 | ||
| 241 | skb->protocol = htons(ETH_P_IPV6); | ||
| 241 | skb->priority = sk->sk_priority; | 242 | skb->priority = sk->sk_priority; |
| 242 | skb->mark = sk->sk_mark; | 243 | skb->mark = sk->sk_mark; |
| 243 | 244 | ||
| @@ -1057,6 +1058,7 @@ static inline int ip6_ufo_append_data(struct sock *sk, | |||
| 1057 | /* initialize protocol header pointer */ | 1058 | /* initialize protocol header pointer */ |
| 1058 | skb->transport_header = skb->network_header + fragheaderlen; | 1059 | skb->transport_header = skb->network_header + fragheaderlen; |
| 1059 | 1060 | ||
| 1061 | skb->protocol = htons(ETH_P_IPV6); | ||
| 1060 | skb->ip_summed = CHECKSUM_PARTIAL; | 1062 | skb->ip_summed = CHECKSUM_PARTIAL; |
| 1061 | skb->csum = 0; | 1063 | skb->csum = 0; |
| 1062 | } | 1064 | } |
| @@ -1359,6 +1361,7 @@ alloc_new_skb: | |||
| 1359 | /* | 1361 | /* |
| 1360 | * Fill in the control structures | 1362 | * Fill in the control structures |
| 1361 | */ | 1363 | */ |
| 1364 | skb->protocol = htons(ETH_P_IPV6); | ||
| 1362 | skb->ip_summed = CHECKSUM_NONE; | 1365 | skb->ip_summed = CHECKSUM_NONE; |
| 1363 | skb->csum = 0; | 1366 | skb->csum = 0; |
| 1364 | /* reserve for fragmentation and ipsec header */ | 1367 | /* reserve for fragmentation and ipsec header */ |
diff --git a/net/ipv6/raw.c b/net/ipv6/raw.c index c45f7a5c36e9..cdaed47ba932 100644 --- a/net/ipv6/raw.c +++ b/net/ipv6/raw.c | |||
| @@ -628,6 +628,7 @@ static int rawv6_send_hdrinc(struct sock *sk, void *from, int length, | |||
| 628 | goto error; | 628 | goto error; |
| 629 | skb_reserve(skb, hlen); | 629 | skb_reserve(skb, hlen); |
| 630 | 630 | ||
| 631 | skb->protocol = htons(ETH_P_IPV6); | ||
| 631 | skb->priority = sk->sk_priority; | 632 | skb->priority = sk->sk_priority; |
| 632 | skb->mark = sk->sk_mark; | 633 | skb->mark = sk->sk_mark; |
| 633 | skb_dst_set(skb, &rt->dst); | 634 | skb_dst_set(skb, &rt->dst); |
