On 8/15/2024 8:32 PM, Adel Belkhiri wrote:
> Hi DPDK Community,
> 
> I am currently working on developing performance analyses for
> applications using the ethdev library. These analyses are being
> implemented in Trace Compass, an open-source performance analyzer. One
> of the views I’ve implemented shows the rate of traffic received or sent
> by an ethernet port, measured in packets per second. However, I've
> encountered an issue with the lib.ethdev.rx.burst event, which triggers
> even when no packets are polled, leading to a significant number of
> irrelevant events in the trace. This becomes problematic as these
> "empty" events can overwhelm the tracer buffer, potentially causing the
> loss of more critical events due to their high frequency.
> 
> To address this, I've modified the DPDK code in lib/ethdev/rte_ethdev.h
> to add a conditional statement that only triggers the event when nb_rx >
> 0. My question to the community is whether there are use cases where an
> "empty" lib.ethdev.rx.burst event could be useful. If not, would there
> be interest in submitting a patch with this modification?
>

Tracepoint is good way to get frequency of the calls, so I believe there
can be value of getting empty burst calls too.

But your usecase also a valid one. I wonder if it works to have separate
trace calls, for empty and non-empty ones, and how this additional
branching impacts the performance, at least branch should be wrapped
with 'RTE_ENABLE_TRACE_FP' macro to not impact non-tracing usage.

Reply via email to