netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH bpf-next] libbpf: add xsk_ring_prod__free() function
@ 2019-06-21 15:25 Eelco Chaudron
  2019-06-21 19:13 ` Andrii Nakryiko
  0 siblings, 1 reply; 6+ messages in thread
From: Eelco Chaudron @ 2019-06-21 15:25 UTC (permalink / raw)
  To: netdev; +Cc: ast, daniel, kafai, songliubraving, yhs

When an AF_XDP application received X packets, it does not mean X
frames can be stuffed into the producer ring. To make it easier for
AF_XDP applications this API allows them to check how many frames can
be added into the ring.

Signed-off-by: Eelco Chaudron <echaudro@redhat.com>
---
 tools/lib/bpf/xsk.h | 6 ++++++
 1 file changed, 6 insertions(+)

diff --git a/tools/lib/bpf/xsk.h b/tools/lib/bpf/xsk.h
index 82ea71a0f3ec..86f3d485e957 100644
--- a/tools/lib/bpf/xsk.h
+++ b/tools/lib/bpf/xsk.h
@@ -95,6 +95,12 @@ static inline __u32 xsk_prod_nb_free(struct xsk_ring_prod *r, __u32 nb)
 	return r->cached_cons - r->cached_prod;
 }
 
+static inline __u32 xsk_ring_prod__free(struct xsk_ring_prod *r)
+{
+	r->cached_cons = *r->consumer + r->size;
+	return r->cached_cons - r->cached_prod;
+}
+
 static inline __u32 xsk_cons_nb_avail(struct xsk_ring_cons *r, __u32 nb)
 {
 	__u32 entries = r->cached_prod - r->cached_cons;
-- 
2.20.1


^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2019-06-25  7:58 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-06-21 15:25 [PATCH bpf-next] libbpf: add xsk_ring_prod__free() function Eelco Chaudron
2019-06-21 19:13 ` Andrii Nakryiko
2019-06-24  9:37   ` Eelco Chaudron
2019-06-24 10:15     ` Magnus Karlsson
2019-06-24 16:42     ` Andrii Nakryiko
2019-06-25  7:58       ` Eelco Chaudron

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).