mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-19 05:36:53 +07:00
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: "Eric W. Biederman" <ebiederm@xmission.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
278d5385b1
commit
4c50254902
@ -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)
|
|||||||
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
|
||||||
|
Loading…
Reference in New Issue
Block a user