aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/ethernet/emulex/benet/be_main.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/ethernet/emulex/benet/be_main.c')
-rw-r--r--drivers/net/ethernet/emulex/benet/be_main.c30
1 files changed, 11 insertions, 19 deletions
diff --git a/drivers/net/ethernet/emulex/benet/be_main.c b/drivers/net/ethernet/emulex/benet/be_main.c
index fe007ea4a01c..b31b0f0789db 100644
--- a/drivers/net/ethernet/emulex/benet/be_main.c
+++ b/drivers/net/ethernet/emulex/benet/be_main.c
@@ -2143,7 +2143,6 @@ static int be_evt_queues_create(struct be_adapter *adapter)
2143 napi_hash_add(&eqo->napi); 2143 napi_hash_add(&eqo->napi);
2144 aic = &adapter->aic_obj[i]; 2144 aic = &adapter->aic_obj[i];
2145 eqo->adapter = adapter; 2145 eqo->adapter = adapter;
2146 eqo->tx_budget = BE_TX_BUDGET;
2147 eqo->idx = i; 2146 eqo->idx = i;
2148 aic->max_eqd = BE_MAX_EQD; 2147 aic->max_eqd = BE_MAX_EQD;
2149 aic->enable = true; 2148 aic->enable = true;
@@ -2459,20 +2458,19 @@ static inline void lancer_update_tx_err(struct be_tx_obj *txo, u32 status)
2459 } 2458 }
2460} 2459}
2461 2460
2462static bool be_process_tx(struct be_adapter *adapter, struct be_tx_obj *txo, 2461static void be_process_tx(struct be_adapter *adapter, struct be_tx_obj *txo,
2463 int budget, int idx) 2462 int idx)
2464{ 2463{
2465 struct be_eth_tx_compl *txcp; 2464 struct be_eth_tx_compl *txcp;
2466 int num_wrbs = 0, work_done; 2465 int num_wrbs = 0, work_done = 0;
2467 u32 compl_status; 2466 u32 compl_status;
2467 u16 last_idx;
2468
2469 while ((txcp = be_tx_compl_get(&txo->cq))) {
2470 last_idx = GET_TX_COMPL_BITS(wrb_index, txcp);
2471 num_wrbs += be_tx_compl_process(adapter, txo, last_idx);
2472 work_done++;
2468 2473
2469 for (work_done = 0; work_done < budget; work_done++) {
2470 txcp = be_tx_compl_get(&txo->cq);
2471 if (!txcp)
2472 break;
2473 num_wrbs += be_tx_compl_process(adapter, txo,
2474 GET_TX_COMPL_BITS(wrb_index,
2475 txcp));
2476 compl_status = GET_TX_COMPL_BITS(status, txcp); 2474 compl_status = GET_TX_COMPL_BITS(status, txcp);
2477 if (compl_status) { 2475 if (compl_status) {
2478 if (lancer_chip(adapter)) 2476 if (lancer_chip(adapter))
@@ -2497,7 +2495,6 @@ static bool be_process_tx(struct be_adapter *adapter, struct be_tx_obj *txo,
2497 tx_stats(txo)->tx_compl += work_done; 2495 tx_stats(txo)->tx_compl += work_done;
2498 u64_stats_update_end(&tx_stats(txo)->sync_compl); 2496 u64_stats_update_end(&tx_stats(txo)->sync_compl);
2499 } 2497 }
2500 return (work_done < budget); /* Done */
2501} 2498}
2502 2499
2503int be_poll(struct napi_struct *napi, int budget) 2500int be_poll(struct napi_struct *napi, int budget)
@@ -2506,17 +2503,12 @@ int be_poll(struct napi_struct *napi, int budget)
2506 struct be_adapter *adapter = eqo->adapter; 2503 struct be_adapter *adapter = eqo->adapter;
2507 int max_work = 0, work, i, num_evts; 2504 int max_work = 0, work, i, num_evts;
2508 struct be_rx_obj *rxo; 2505 struct be_rx_obj *rxo;
2509 bool tx_done;
2510 2506
2511 num_evts = events_get(eqo); 2507 num_evts = events_get(eqo);
2512 2508
2513 /* Process all TXQs serviced by this EQ */ 2509 /* Process all TXQs serviced by this EQ */
2514 for (i = eqo->idx; i < adapter->num_tx_qs; i += adapter->num_evt_qs) { 2510 for (i = eqo->idx; i < adapter->num_tx_qs; i += adapter->num_evt_qs)
2515 tx_done = be_process_tx(adapter, &adapter->tx_obj[i], 2511 be_process_tx(adapter, &adapter->tx_obj[i], i);
2516 eqo->tx_budget, i);
2517 if (!tx_done)
2518 max_work = budget;
2519 }
2520 2512
2521 if (be_lock_napi(eqo)) { 2513 if (be_lock_napi(eqo)) {
2522 /* This loop will iterate twice for EQ0 in which 2514 /* This loop will iterate twice for EQ0 in which