skbuff: simplify __alloc_skb() a bit
authorAlexander Lobakin <alobakin@pm.me>
Sat, 13 Feb 2021 14:11:39 +0000 (14:11 +0000)
committerDavid S. Miller <davem@davemloft.net>
Sat, 13 Feb 2021 22:32:03 +0000 (14:32 -0800)
Use unlikely() annotations for skbuff_head and data similarly to the
two other allocation functions and remove totally redundant goto.

Signed-off-by: Alexander Lobakin <alobakin@pm.me>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/core/skbuff.c

index c7d184e11547069495ddf4a6c319ea1170ee5de2..88566de26cd1c26cf3b43ab5467df6a2da0527fe 100644 (file)
@@ -339,8 +339,8 @@ struct sk_buff *__alloc_skb(unsigned int size, gfp_t gfp_mask,
 
        /* Get the HEAD */
        skb = kmem_cache_alloc_node(cache, gfp_mask & ~__GFP_DMA, node);
-       if (!skb)
-               goto out;
+       if (unlikely(!skb))
+               return NULL;
        prefetchw(skb);
 
        /* We do our best to align skb_shared_info on a separate cache
@@ -351,7 +351,7 @@ struct sk_buff *__alloc_skb(unsigned int size, gfp_t gfp_mask,
        size = SKB_DATA_ALIGN(size);
        size += SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
        data = kmalloc_reserve(size, gfp_mask, node, &pfmemalloc);
-       if (!data)
+       if (unlikely(!data))
                goto nodata;
        /* kmalloc(size) might give us more room than requested.
         * Put skb_shared_info exactly at the end of allocated zone,
@@ -395,12 +395,11 @@ struct sk_buff *__alloc_skb(unsigned int size, gfp_t gfp_mask,
 
        skb_set_kcov_handle(skb, kcov_common_handle());
 
-out:
        return skb;
+
 nodata:
        kmem_cache_free(cache, skb);
-       skb = NULL;
-       goto out;
+       return NULL;
 }
 EXPORT_SYMBOL(__alloc_skb);