From: Eric Dumazet Date: Fri, 21 Apr 2023 09:43:56 +0000 (+0000) Subject: net: make napi_threaded_poll() aware of sd->defer_list X-Git-Tag: Ubuntu-6.5.0-9.9~2832^2~21^2~1 X-Git-Url: https://git.proxmox.com/?a=commitdiff_plain;h=a1aaee7f8f79d1b0595e24f8c3caed24630d6cb6;p=mirror_ubuntu-kernels.git net: make napi_threaded_poll() aware of sd->defer_list If we call skb_defer_free_flush() from napi_threaded_poll(), we can avoid to raise IPI from skb_attempt_defer_free() when the list becomes too big. This allows napi_threaded_poll() to rely less on softirqs, and lowers latency caused by a too big list. Signed-off-by: Eric Dumazet Signed-off-by: David S. Miller --- diff --git a/net/core/dev.c b/net/core/dev.c index 81ded215731b..7d9ec23f97c6 100644 --- a/net/core/dev.c +++ b/net/core/dev.c @@ -6622,6 +6622,7 @@ static void skb_defer_free_flush(struct softnet_data *sd) static int napi_threaded_poll(void *data) { struct napi_struct *napi = data; + struct softnet_data *sd; void *have; while (!napi_thread_wait(napi)) { @@ -6629,11 +6630,13 @@ static int napi_threaded_poll(void *data) bool repoll = false; local_bh_disable(); + sd = this_cpu_ptr(&softnet_data); have = netpoll_poll_lock(napi); __napi_poll(napi, &repoll); netpoll_poll_unlock(have); + skb_defer_free_flush(sd); local_bh_enable(); if (!repoll)