* [DPDK/other Bug 1816] bpf ethdev tx filtering semantic issues
@ 2025-10-29 21:06 bugzilla
0 siblings, 0 replies; only message in thread
From: bugzilla @ 2025-10-29 21:06 UTC (permalink / raw)
To: dev
http://bugs.dpdk.org/show_bug.cgi?id=1816
Bug ID: 1816
Summary: bpf ethdev tx filtering semantic issues
Product: DPDK
Version: 25.07
Hardware: All
OS: All
Status: UNCONFIRMED
Severity: major
Priority: Normal
Component: other
Assignee: dev@dpdk.org
Reporter: stephen@networkplumber.org
Target Milestone: ---
If the function rte_bpf_eth_tx_elf_load() is used to load a filter on a queue
can cause duplicate mbuf usage issues.
For normal PMD transmit if rte_eth_tx_burst() returns a value smaller than the
request number of packets; then the application will assume that this is
because the transmit descriptor queue in the PMD is full. The unsent buffers
will not be freed by the PMD, and is up to the application to either free (or
resend) those mbufs.
The issue is that the transmit call back filter can return a smaller value than
requested if some packets were filtered. The BPF filter code drops the filtered
out packets.
In the simplest case, a common practice will cause duplicate free:
sent = rte_eth_tx_burst(port, queue, pkts, nb_pkts);
if (sent < nb_pkts)
rte_pktmbuf_free_bulk(pkts + sent, nb_pkts - sent);
Alternatives are:
- redefining the meaning of tx_burst such that rte_eth_tx_burst frees
major application impact
- treat filtered packets as if sent
--
You are receiving this mail because:
You are the assignee for the bug.
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2025-10-29 21:06 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-10-29 21:06 [DPDK/other Bug 1816] bpf ethdev tx filtering semantic issues bugzilla
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).