diff options
| -rw-r--r-- | net/core/skbuff.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index edf40ac0cd07..a3cb0be4c6f3 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c | |||
| @@ -1178,7 +1178,7 @@ int skb_copy_ubufs(struct sk_buff *skb, gfp_t gfp_mask) | |||
| 1178 | u32 d_off; | 1178 | u32 d_off; |
| 1179 | 1179 | ||
| 1180 | if (!num_frags) | 1180 | if (!num_frags) |
| 1181 | return 0; | 1181 | goto release; |
| 1182 | 1182 | ||
| 1183 | if (skb_shared(skb) || skb_unclone(skb, gfp_mask)) | 1183 | if (skb_shared(skb) || skb_unclone(skb, gfp_mask)) |
| 1184 | return -EINVAL; | 1184 | return -EINVAL; |
| @@ -1238,6 +1238,7 @@ int skb_copy_ubufs(struct sk_buff *skb, gfp_t gfp_mask) | |||
| 1238 | __skb_fill_page_desc(skb, new_frags - 1, head, 0, d_off); | 1238 | __skb_fill_page_desc(skb, new_frags - 1, head, 0, d_off); |
| 1239 | skb_shinfo(skb)->nr_frags = new_frags; | 1239 | skb_shinfo(skb)->nr_frags = new_frags; |
| 1240 | 1240 | ||
| 1241 | release: | ||
| 1241 | skb_zcopy_clear(skb, false); | 1242 | skb_zcopy_clear(skb, false); |
| 1242 | return 0; | 1243 | return 0; |
| 1243 | } | 1244 | } |
