2021-12-13 18:15:07 +01:00
|
|
|
From: Felix Fietkau <nbd@nbd.name>
|
|
|
|
Date: Mon, 8 Feb 2021 11:34:08 -0800
|
|
|
|
Subject: [PATCH] net: extract napi poll functionality to __napi_poll()
|
|
|
|
|
|
|
|
This commit introduces a new function __napi_poll() which does the main
|
|
|
|
logic of the existing napi_poll() function, and will be called by other
|
|
|
|
functions in later commits.
|
|
|
|
This idea and implementation is done by Felix Fietkau <nbd@nbd.name> and
|
|
|
|
is proposed as part of the patch to move napi work to work_queue
|
|
|
|
context.
|
|
|
|
This commit by itself is a code restructure.
|
|
|
|
|
|
|
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
|
|
Signed-off-by: Wei Wang <weiwan@google.com>
|
|
|
|
Reviewed-by: Alexander Duyck <alexanderduyck@fb.com>
|
|
|
|
Signed-off-by: David S. Miller <davem@davemloft.net>
|
|
|
|
---
|
|
|
|
|
|
|
|
--- a/net/core/dev.c
|
|
|
|
+++ b/net/core/dev.c
|
2023-06-01 19:58:05 +08:00
|
|
|
@@ -6330,15 +6330,10 @@ void netif_napi_del(struct napi_struct *
|
2021-12-13 18:15:07 +01:00
|
|
|
}
|
|
|
|
EXPORT_SYMBOL(netif_napi_del);
|
|
|
|
|
|
|
|
-static int napi_poll(struct napi_struct *n, struct list_head *repoll)
|
|
|
|
+static int __napi_poll(struct napi_struct *n, bool *repoll)
|
|
|
|
{
|
|
|
|
- void *have;
|
|
|
|
int work, weight;
|
|
|
|
|
|
|
|
- list_del_init(&n->poll_list);
|
|
|
|
-
|
|
|
|
- have = netpoll_poll_lock(n);
|
|
|
|
-
|
|
|
|
weight = n->weight;
|
|
|
|
|
|
|
|
/* This NAPI_STATE_SCHED test is for avoiding a race
|
2023-06-01 19:58:05 +08:00
|
|
|
@@ -6356,7 +6351,7 @@ static int napi_poll(struct napi_struct
|
2021-12-13 18:15:07 +01:00
|
|
|
WARN_ON_ONCE(work > weight);
|
|
|
|
|
|
|
|
if (likely(work < weight))
|
|
|
|
- goto out_unlock;
|
|
|
|
+ return work;
|
|
|
|
|
|
|
|
/* Drivers must not modify the NAPI state if they
|
|
|
|
* consume the entire weight. In such cases this code
|
2023-06-01 19:58:05 +08:00
|
|
|
@@ -6365,7 +6360,7 @@ static int napi_poll(struct napi_struct
|
2021-12-13 18:15:07 +01:00
|
|
|
*/
|
|
|
|
if (unlikely(napi_disable_pending(n))) {
|
|
|
|
napi_complete(n);
|
|
|
|
- goto out_unlock;
|
|
|
|
+ return work;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (n->gro_bitmask) {
|
2023-06-01 19:58:05 +08:00
|
|
|
@@ -6383,12 +6378,29 @@ static int napi_poll(struct napi_struct
|
2021-12-13 18:15:07 +01:00
|
|
|
if (unlikely(!list_empty(&n->poll_list))) {
|
|
|
|
pr_warn_once("%s: Budget exhausted after napi rescheduled\n",
|
|
|
|
n->dev ? n->dev->name : "backlog");
|
|
|
|
- goto out_unlock;
|
|
|
|
+ return work;
|
|
|
|
}
|
|
|
|
|
|
|
|
- list_add_tail(&n->poll_list, repoll);
|
|
|
|
+ *repoll = true;
|
|
|
|
+
|
|
|
|
+ return work;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static int napi_poll(struct napi_struct *n, struct list_head *repoll)
|
|
|
|
+{
|
|
|
|
+ bool do_repoll = false;
|
|
|
|
+ void *have;
|
|
|
|
+ int work;
|
|
|
|
+
|
|
|
|
+ list_del_init(&n->poll_list);
|
|
|
|
+
|
|
|
|
+ have = netpoll_poll_lock(n);
|
|
|
|
+
|
|
|
|
+ work = __napi_poll(n, &do_repoll);
|
|
|
|
+
|
|
|
|
+ if (do_repoll)
|
|
|
|
+ list_add_tail(&n->poll_list, repoll);
|
|
|
|
|
|
|
|
-out_unlock:
|
|
|
|
netpoll_poll_unlock(have);
|
|
|
|
|
|
|
|
return work;
|