On Sat, May 09, 2015 at 04:27:12PM +0000, Clark, Gilbert wrote:
> 
> Hi folks:
> 
> I'm brand new to DPDK.? Read about it off and on occasionally, but never had 
> the chance to sit down and play with things until now. ?It's been fun so far: 
> just been working on a few toy applications to get myself started.
> 
> I have run into a question, though: when calling rte_eth_tx_burst with a 
> ring-backed PMD I've set up, the mbufs I've sent never seem to be freed.? 
> This seems to make some degree of sense, but ... since I'm new, and because 
> the documentation says rte_eth_tx_burst should eventually free mbufs that are 
> sent [1], I wanted to make sure I'm on track and not just misunderstanding 
> the way something works [2].
> 
> Thanks,
> Gilbert Clark
> 
> [1] From http://dpdk.org/doc/api/rte__ethdev_8h.html?:
> 
> It is the responsibility of the rte_eth_tx_burst() function to transparently 
> free the memory buffers of packets previously sent
> 
> [2] From lib/librte_pmd_ring.c:
> 
> static uint16_t
> eth_ring_tx(void *q, struct rte_mbuf **bufs, uint16_t nb_bufs)
> {
>     void **ptrs = (void *)&bufs[0];
>     struct ring_queue *r = q;
>     const uint16_t nb_tx = (uint16_t)rte_ring_enqueue_burst(r->rng,
>             ptrs, nb_bufs);
>     if (r->rng->flags & RING_F_SP_ENQ) {
>         r->tx_pkts.cnt += nb_tx;
>         r->err_pkts.cnt += nb_bufs - nb_tx;
>     } else {
>         rte_atomic64_add(&(r->tx_pkts), nb_tx);
>         rte_atomic64_add(&(r->err_pkts), nb_bufs - nb_tx);
>     }
>     return nb_tx;
> }
> 
> This doesn't ever appear to free a transmitted mbuf ... unless there's code 
> to do that somewhere else that I'm missing?

Indeed it doesn't free the mbufs, because this is not a PMD backed by real 
hardware
so the packets are never actually transmitted anywhere, just passed to the other
end of the ring. To behave strictly like a physical PMD, we would copy the sent
packet to a new buffer on RX, and free the old one. 
However, in this case, we take a shortcut and just pass the same mbuf on RX as
was passed on TX, which saves the cycles for buffer management.

To see buffer freeing on TX occur, I suggest you look at some of the other PMDs,
perhaps the e1000/igb PMD?

/Bruce

Reply via email to