|
@@ -1056,15 +1056,23 @@ static int udp_v6_send_skb(struct sk_buff *skb, struct flowi6 *fl6,
|
|
|
const int hlen = skb_network_header_len(skb) +
|
|
const int hlen = skb_network_header_len(skb) +
|
|
|
sizeof(struct udphdr);
|
|
sizeof(struct udphdr);
|
|
|
|
|
|
|
|
- if (hlen + cork->gso_size > cork->fragsize)
|
|
|
|
|
|
|
+ if (hlen + cork->gso_size > cork->fragsize) {
|
|
|
|
|
+ kfree_skb(skb);
|
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
|
- if (skb->len > cork->gso_size * UDP_MAX_SEGMENTS)
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (skb->len > cork->gso_size * UDP_MAX_SEGMENTS) {
|
|
|
|
|
+ kfree_skb(skb);
|
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
|
- if (udp_sk(sk)->no_check6_tx)
|
|
|
|
|
|
|
+ }
|
|
|
|
|
+ if (udp_sk(sk)->no_check6_tx) {
|
|
|
|
|
+ kfree_skb(skb);
|
|
|
return -EINVAL;
|
|
return -EINVAL;
|
|
|
|
|
+ }
|
|
|
if (skb->ip_summed != CHECKSUM_PARTIAL || is_udplite ||
|
|
if (skb->ip_summed != CHECKSUM_PARTIAL || is_udplite ||
|
|
|
- dst_xfrm(skb_dst(skb)))
|
|
|
|
|
|
|
+ dst_xfrm(skb_dst(skb))) {
|
|
|
|
|
+ kfree_skb(skb);
|
|
|
return -EIO;
|
|
return -EIO;
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
skb_shinfo(skb)->gso_size = cork->gso_size;
|
|
skb_shinfo(skb)->gso_size = cork->gso_size;
|
|
|
skb_shinfo(skb)->gso_type = SKB_GSO_UDP_L4;
|
|
skb_shinfo(skb)->gso_type = SKB_GSO_UDP_L4;
|