Commit 7d7072e3 authored by Michael S. Tsirkin's avatar Michael S. Tsirkin Committed by David S. Miller

skb_array: resize support

Update skb_array after ptr_ring API changes.
Signed-off-by: default avatarMichael S. Tsirkin <mst@redhat.com>
Acked-by: default avatarJesper Dangaard Brouer <brouer@redhat.com>
Tested-by: default avatarJesper Dangaard Brouer <brouer@redhat.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 5d49de53
...@@ -63,9 +63,9 @@ static inline int skb_array_produce_any(struct skb_array *a, struct sk_buff *skb ...@@ -63,9 +63,9 @@ static inline int skb_array_produce_any(struct skb_array *a, struct sk_buff *skb
return ptr_ring_produce_any(&a->ring, skb); return ptr_ring_produce_any(&a->ring, skb);
} }
/* Might be slightly faster than skb_array_empty below, but callers invoking /* Might be slightly faster than skb_array_empty below, but only safe if the
* this in a loop must take care to use a compiler barrier, for example * array is never resized. Also, callers invoking this in a loop must take care
* cpu_relax(). * to use a compiler barrier, for example cpu_relax().
*/ */
static inline bool __skb_array_empty(struct skb_array *a) static inline bool __skb_array_empty(struct skb_array *a)
{ {
...@@ -77,6 +77,21 @@ static inline bool skb_array_empty(struct skb_array *a) ...@@ -77,6 +77,21 @@ static inline bool skb_array_empty(struct skb_array *a)
return ptr_ring_empty(&a->ring); return ptr_ring_empty(&a->ring);
} }
static inline bool skb_array_empty_bh(struct skb_array *a)
{
return ptr_ring_empty_bh(&a->ring);
}
static inline bool skb_array_empty_irq(struct skb_array *a)
{
return ptr_ring_empty_irq(&a->ring);
}
static inline bool skb_array_empty_any(struct skb_array *a)
{
return ptr_ring_empty_any(&a->ring);
}
static inline struct sk_buff *skb_array_consume(struct skb_array *a) static inline struct sk_buff *skb_array_consume(struct skb_array *a)
{ {
return ptr_ring_consume(&a->ring); return ptr_ring_consume(&a->ring);
...@@ -136,9 +151,19 @@ static inline int skb_array_init(struct skb_array *a, int size, gfp_t gfp) ...@@ -136,9 +151,19 @@ static inline int skb_array_init(struct skb_array *a, int size, gfp_t gfp)
return ptr_ring_init(&a->ring, size, gfp); return ptr_ring_init(&a->ring, size, gfp);
} }
void __skb_array_destroy_skb(void *ptr)
{
kfree_skb(ptr);
}
int skb_array_resize(struct skb_array *a, int size, gfp_t gfp)
{
return ptr_ring_resize(&a->ring, size, gfp, __skb_array_destroy_skb);
}
static inline void skb_array_cleanup(struct skb_array *a) static inline void skb_array_cleanup(struct skb_array *a)
{ {
ptr_ring_cleanup(&a->ring); ptr_ring_cleanup(&a->ring, __skb_array_destroy_skb);
} }
#endif /* _LINUX_SKB_ARRAY_H */ #endif /* _LINUX_SKB_ARRAY_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment