Thread (26 messages) 26 messages, 9 authors, 2023-09-22

Re: [RFC PATCH net-next 1/2] net: Use SMP threads for backlog NAPI.

From: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Date: 2023-09-22 07:26:58
Also in: lkml

On 2023-09-21 12:41:33 [+0200], Ferenc Fejes wrote:
Hi!
Hi,
quoted
If we could somehow define a DoS condition once we are overwhelmed
with
packets, then we could act on it and throttle it. This in turn would
allow a SCHED_FIFO priority without the fear of a lockup if the
system
is flooded with packets.
Can this be avoided if we reuse gro_flush_timeout as the maximum time
the NAPI thread can be scheduled?
First your run time needs to be accounted somehow. I observed that some
cards/ systems tend pull often a few packets on each interrupt and
others pull more packets at a time.
So probably packets in a time frame would make sense. Maybe even plus
packet size assuming larger packets require more processing time.

If you run at SCHED_OTHER you don't care, you can keep it running. With
SCHED_FIFO you would need to decide:
- how much is too much
- what to do once you reach too much

Once you reach too much you could:
- change the scheduling policy to SCHED_OTHER and keep going until it is
  no longer "too much in a given period" so you can flip it back.

- stop processing for a period of time and risk packet loss which is
  defined as better than to continue.

- pulling packets and dropping them instead of injecting into the stack.
  Using xdp/ebpf might be easy since there is an API for that. One could
  even peek at packets to decide if some can be kept.
  This would rely on the fact that the system can do this quick enough
  under a DoS condition.
Ferenc
Sebastian
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help