DPDK patches and discussions
 help / color / mirror / Atom feed
* Thread priority for background tasks
@ 2025-04-30 18:40 Morten Brørup
  2025-04-30 19:45 ` Stephen Hemminger
  0 siblings, 1 reply; 2+ messages in thread
From: Morten Brørup @ 2025-04-30 18:40 UTC (permalink / raw)
  To: dev

There are only two thread priorities in the enum rte_thread_priority: Normal and Real-time Critical.

I would like to poll ethdev counters, collect garbage and perform other jitter non-sensitive tasks in a control thread with lower priority than my ordinary control threads, so it will be preempted by any work ready for my ordinary control threads.

Which DPDK API am I supposed to use to assign this below-normal priority to my "background" control thread?

Or: Aren't we missing a priority like Linux' SCHED_BATCH?


Med venlig hilsen / Kind regards,
-Morten Brørup


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

* Re: Thread priority for background tasks
  2025-04-30 18:40 Thread priority for background tasks Morten Brørup
@ 2025-04-30 19:45 ` Stephen Hemminger
  0 siblings, 0 replies; 2+ messages in thread
From: Stephen Hemminger @ 2025-04-30 19:45 UTC (permalink / raw)
  To: Morten Brørup; +Cc: dev

On Wed, 30 Apr 2025 20:40:52 +0200
Morten Brørup <mb@smartsharesystems.com> wrote:

> There are only two thread priorities in the enum rte_thread_priority: Normal and Real-time Critical.
> 
> I would like to poll ethdev counters, collect garbage and perform other jitter non-sensitive tasks in a control thread with lower priority than my ordinary control threads, so it will be preempted by any work ready for my ordinary control threads.
> 
> Which DPDK API am I supposed to use to assign this below-normal priority to my "background" control thread?
> 
> Or: Aren't we missing a priority like Linux' SCHED_BATCH?
> 
> 
> Med venlig hilsen / Kind regards,
> -Morten Brørup
> 

Short answer: if your application is running on Linux, only ever use Normal.
DPDK applications usually never sleep and this will starve the OS and cause instability.

Long answer:
Realtime critical was added for Windows, which needs it and doesn't do the
same real RT behavior. Might work on FreeBSD, not sure how the scheduler works.

On Linux, it is possible to use but only if the application is not a 100% polling.
(i.e a real time application not a polling application).
It needs to regularly sleep to allow non-RT kernel threads to run, otherwise things
like disk writes that are pending on that CPU may not happen, leading to filesystem
corruption. Or hangs.

Bottom line:
Real time critical means this needs to run for a short time now (i.e safety switch).
RT does not mean this is more important overall, or needs to run faster.

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

end of thread, other threads:[~2025-04-30 19:45 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2025-04-30 18:40 Thread priority for background tasks Morten Brørup
2025-04-30 19:45 ` Stephen Hemminger

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).