Commit 4c502549 authored by Eric W. Biederman's avatar Eric W. Biederman Committed by David S. Miller

enic: Don't receive packets when the napi budget == 0

Processing any incoming packets with a with a napi budget of 0
is incorrect driver behavior.

This matters as netpoll will shortly call drivers with a budget of 0
to avoid receive packet processing happening in hard irq context.
Signed-off-by: default avatar"Eric W. Biederman" <ebiederm@xmission.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 278d5385
...@@ -1086,14 +1086,15 @@ static int enic_poll(struct napi_struct *napi, int budget) ...@@ -1086,14 +1086,15 @@ static int enic_poll(struct napi_struct *napi, int budget)
unsigned int intr = enic_legacy_io_intr(); unsigned int intr = enic_legacy_io_intr();
unsigned int rq_work_to_do = budget; unsigned int rq_work_to_do = budget;
unsigned int wq_work_to_do = -1; /* no limit */ unsigned int wq_work_to_do = -1; /* no limit */
unsigned int work_done, rq_work_done, wq_work_done; unsigned int work_done, rq_work_done = 0, wq_work_done;
int err; int err;
/* Service RQ (first) and WQ /* Service RQ (first) and WQ
*/ */
rq_work_done = vnic_cq_service(&enic->cq[cq_rq], if (budget > 0)
rq_work_to_do, enic_rq_service, NULL); rq_work_done = vnic_cq_service(&enic->cq[cq_rq],
rq_work_to_do, enic_rq_service, NULL);
wq_work_done = vnic_cq_service(&enic->cq[cq_wq], wq_work_done = vnic_cq_service(&enic->cq[cq_wq],
wq_work_to_do, enic_wq_service, NULL); wq_work_to_do, enic_wq_service, NULL);
...@@ -1141,14 +1142,15 @@ static int enic_poll_msix(struct napi_struct *napi, int budget) ...@@ -1141,14 +1142,15 @@ static int enic_poll_msix(struct napi_struct *napi, int budget)
unsigned int cq = enic_cq_rq(enic, rq); unsigned int cq = enic_cq_rq(enic, rq);
unsigned int intr = enic_msix_rq_intr(enic, rq); unsigned int intr = enic_msix_rq_intr(enic, rq);
unsigned int work_to_do = budget; unsigned int work_to_do = budget;
unsigned int work_done; unsigned int work_done = 0;
int err; int err;
/* Service RQ /* Service RQ
*/ */
work_done = vnic_cq_service(&enic->cq[cq], if (budget > 0)
work_to_do, enic_rq_service, NULL); work_done = vnic_cq_service(&enic->cq[cq],
work_to_do, enic_rq_service, NULL);
/* Return intr event credits for this polling /* Return intr event credits for this polling
* cycle. An intr event is the completion of a * cycle. An intr event is the completion of a
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment