mirror of
https://github.com/adulau/aha.git
synced 2024-12-29 04:06:22 +00:00
[IPV4/IPV6] multicast: Check add_grhead() return value
add_grhead() allocates memory with GFP_ATOMIC and in at least two places skb from it passed to skb_put() without checking. Signed-off-by: Alexey Dobriyan <adobriyan@openvz.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
f2f2102d1a
commit
cc63f70b8b
2 changed files with 4 additions and 0 deletions
|
@ -455,6 +455,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ip_mc_list *pmc,
|
||||||
skb = add_grhead(skb, pmc, type, &pgr);
|
skb = add_grhead(skb, pmc, type, &pgr);
|
||||||
first = 0;
|
first = 0;
|
||||||
}
|
}
|
||||||
|
if (!skb)
|
||||||
|
return NULL;
|
||||||
psrc = (__be32 *)skb_put(skb, sizeof(__be32));
|
psrc = (__be32 *)skb_put(skb, sizeof(__be32));
|
||||||
*psrc = psf->sf_inaddr;
|
*psrc = psf->sf_inaddr;
|
||||||
scount++; stotal++;
|
scount++; stotal++;
|
||||||
|
|
|
@ -1582,6 +1582,8 @@ static struct sk_buff *add_grec(struct sk_buff *skb, struct ifmcaddr6 *pmc,
|
||||||
skb = add_grhead(skb, pmc, type, &pgr);
|
skb = add_grhead(skb, pmc, type, &pgr);
|
||||||
first = 0;
|
first = 0;
|
||||||
}
|
}
|
||||||
|
if (!skb)
|
||||||
|
return NULL;
|
||||||
psrc = (struct in6_addr *)skb_put(skb, sizeof(*psrc));
|
psrc = (struct in6_addr *)skb_put(skb, sizeof(*psrc));
|
||||||
*psrc = psf->sf_addr;
|
*psrc = psf->sf_addr;
|
||||||
scount++; stotal++;
|
scount++; stotal++;
|
||||||
|
|
Loading…
Reference in a new issue