Commit f382d03a authored by YOSHIFUJI Hideaki / 吉藤英明's avatar YOSHIFUJI Hideaki / 吉藤英明 Committed by David S. Miller

ndisc: Set skb->dev and skb->protocol inside ndisc_alloc_skb().

Signed-off-by: default avatarYOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent c8d6c380
...@@ -384,21 +384,21 @@ static struct sk_buff *ndisc_alloc_skb(struct net_device *dev, ...@@ -384,21 +384,21 @@ static struct sk_buff *ndisc_alloc_skb(struct net_device *dev,
return NULL; return NULL;
} }
skb->protocol = htons(ETH_P_IPV6);
skb->dev = dev;
skb_reserve(skb, hlen); skb_reserve(skb, hlen);
return skb; return skb;
} }
static void ip6_nd_hdr(struct sk_buff *skb, struct net_device *dev, static void ip6_nd_hdr(struct sk_buff *skb,
const struct in6_addr *saddr, const struct in6_addr *saddr,
const struct in6_addr *daddr, const struct in6_addr *daddr,
int hop_limit, int len) int hop_limit, int len)
{ {
struct ipv6hdr *hdr; struct ipv6hdr *hdr;
skb->protocol = htons(ETH_P_IPV6);
skb->dev = dev;
skb_reset_network_header(skb); skb_reset_network_header(skb);
skb_put(skb, sizeof(struct ipv6hdr)); skb_put(skb, sizeof(struct ipv6hdr));
hdr = ipv6_hdr(skb); hdr = ipv6_hdr(skb);
...@@ -438,7 +438,7 @@ static struct sk_buff *ndisc_build_skb(struct net_device *dev, ...@@ -438,7 +438,7 @@ static struct sk_buff *ndisc_build_skb(struct net_device *dev,
if (!skb) if (!skb)
return NULL; return NULL;
ip6_nd_hdr(skb, dev, saddr, daddr, inet6_sk(sk)->hop_limit, len); ip6_nd_hdr(skb, saddr, daddr, inet6_sk(sk)->hop_limit, len);
skb->transport_header = skb->tail; skb->transport_header = skb->tail;
skb_put(skb, len); skb_put(skb, len);
...@@ -1479,7 +1479,7 @@ void ndisc_send_redirect(struct sk_buff *skb, const struct in6_addr *target) ...@@ -1479,7 +1479,7 @@ void ndisc_send_redirect(struct sk_buff *skb, const struct in6_addr *target)
if (!buff) if (!buff)
goto release; goto release;
ip6_nd_hdr(buff, dev, &saddr_buf, &ipv6_hdr(skb)->saddr, ip6_nd_hdr(buff, &saddr_buf, &ipv6_hdr(skb)->saddr,
inet6_sk(sk)->hop_limit, len); inet6_sk(sk)->hop_limit, len);
skb_set_transport_header(buff, skb_tail_pointer(buff) - buff->data); skb_set_transport_header(buff, skb_tail_pointer(buff) - buff->data);
......
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