|
@@ -1313,6 +1313,31 @@ mld_scount(struct ifmcaddr6 *pmc, int type, int gdeleted, int sdeleted)
|
|
|
return scount;
|
|
|
}
|
|
|
|
|
|
+static void ip6_mc_hdr(struct sock *sk, struct sk_buff *skb,
|
|
|
+ struct net_device *dev,
|
|
|
+ const struct in6_addr *saddr,
|
|
|
+ const struct in6_addr *daddr,
|
|
|
+ int proto, int len)
|
|
|
+{
|
|
|
+ struct ipv6hdr *hdr;
|
|
|
+
|
|
|
+ skb->protocol = htons(ETH_P_IPV6);
|
|
|
+ skb->dev = dev;
|
|
|
+
|
|
|
+ skb_reset_network_header(skb);
|
|
|
+ skb_put(skb, sizeof(struct ipv6hdr));
|
|
|
+ hdr = ipv6_hdr(skb);
|
|
|
+
|
|
|
+ ip6_flow_hdr(hdr, 0, 0);
|
|
|
+
|
|
|
+ hdr->payload_len = htons(len);
|
|
|
+ hdr->nexthdr = proto;
|
|
|
+ hdr->hop_limit = inet6_sk(sk)->hop_limit;
|
|
|
+
|
|
|
+ hdr->saddr = *saddr;
|
|
|
+ hdr->daddr = *daddr;
|
|
|
+}
|
|
|
+
|
|
|
static struct sk_buff *mld_newpack(struct net_device *dev, int size)
|
|
|
{
|
|
|
struct net *net = dev_net(dev);
|
|
@@ -1348,7 +1373,7 @@ static struct sk_buff *mld_newpack(struct net_device *dev, int size)
|
|
|
} else
|
|
|
saddr = &addr_buf;
|
|
|
|
|
|
- ip6_nd_hdr(sk, skb, dev, saddr, &mld2_all_mcr, NEXTHDR_HOP, 0);
|
|
|
+ ip6_mc_hdr(sk, skb, dev, saddr, &mld2_all_mcr, NEXTHDR_HOP, 0);
|
|
|
|
|
|
memcpy(skb_put(skb, sizeof(ra)), ra, sizeof(ra));
|
|
|
|
|
@@ -1740,7 +1765,7 @@ static void igmp6_send(struct in6_addr *addr, struct net_device *dev, int type)
|
|
|
} else
|
|
|
saddr = &addr_buf;
|
|
|
|
|
|
- ip6_nd_hdr(sk, skb, dev, saddr, snd_addr, NEXTHDR_HOP, payload_len);
|
|
|
+ ip6_mc_hdr(sk, skb, dev, saddr, snd_addr, NEXTHDR_HOP, payload_len);
|
|
|
|
|
|
memcpy(skb_put(skb, sizeof(ra)), ra, sizeof(ra));
|
|
|
|