[DPDK/other Bug 1816] bpf ethdev tx filtering semantic issues

bugzilla at dpdk.org bugzilla at dpdk.org
Wed Oct 29 22:06:18 CET 2025


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 at dpdk.org
          Reporter: stephen at 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.


More information about the dev mailing list