aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc/efx.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/sfc/efx.c')
-rw-r--r--drivers/net/sfc/efx.c27
1 files changed, 10 insertions, 17 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c
index 22004a612d2c..864095ea5b37 100644
--- a/drivers/net/sfc/efx.c
+++ b/drivers/net/sfc/efx.c
@@ -160,14 +160,16 @@ static void efx_fini_channels(struct efx_nic *efx);
160 */ 160 */
161static int efx_process_channel(struct efx_channel *channel, int rx_quota) 161static int efx_process_channel(struct efx_channel *channel, int rx_quota)
162{ 162{
163 int rxdmaqs; 163 struct efx_nic *efx = channel->efx;
164 struct efx_rx_queue *rx_queue; 164 int rx_packets;
165 165
166 if (unlikely(channel->efx->reset_pending != RESET_TYPE_NONE || 166 if (unlikely(efx->reset_pending != RESET_TYPE_NONE ||
167 !channel->enabled)) 167 !channel->enabled))
168 return rx_quota; 168 return 0;
169 169
170 rxdmaqs = falcon_process_eventq(channel, &rx_quota); 170 rx_packets = falcon_process_eventq(channel, rx_quota);
171 if (rx_packets == 0)
172 return 0;
171 173
172 /* Deliver last RX packet. */ 174 /* Deliver last RX packet. */
173 if (channel->rx_pkt) { 175 if (channel->rx_pkt) {
@@ -179,16 +181,9 @@ static int efx_process_channel(struct efx_channel *channel, int rx_quota)
179 efx_flush_lro(channel); 181 efx_flush_lro(channel);
180 efx_rx_strategy(channel); 182 efx_rx_strategy(channel);
181 183
182 /* Refill descriptor rings as necessary */ 184 efx_fast_push_rx_descriptors(&efx->rx_queue[channel->channel]);
183 rx_queue = &channel->efx->rx_queue[0];
184 while (rxdmaqs) {
185 if (rxdmaqs & 0x01)
186 efx_fast_push_rx_descriptors(rx_queue);
187 rx_queue++;
188 rxdmaqs >>= 1;
189 }
190 185
191 return rx_quota; 186 return rx_packets;
192} 187}
193 188
194/* Mark channel as finished processing 189/* Mark channel as finished processing
@@ -218,14 +213,12 @@ static int efx_poll(struct napi_struct *napi, int budget)
218 struct efx_channel *channel = 213 struct efx_channel *channel =
219 container_of(napi, struct efx_channel, napi_str); 214 container_of(napi, struct efx_channel, napi_str);
220 struct net_device *napi_dev = channel->napi_dev; 215 struct net_device *napi_dev = channel->napi_dev;
221 int unused;
222 int rx_packets; 216 int rx_packets;
223 217
224 EFX_TRACE(channel->efx, "channel %d NAPI poll executing on CPU %d\n", 218 EFX_TRACE(channel->efx, "channel %d NAPI poll executing on CPU %d\n",
225 channel->channel, raw_smp_processor_id()); 219 channel->channel, raw_smp_processor_id());
226 220
227 unused = efx_process_channel(channel, budget); 221 rx_packets = efx_process_channel(channel, budget);
228 rx_packets = (budget - unused);
229 222
230 if (rx_packets < budget) { 223 if (rx_packets < budget) {
231 /* There is no race here; although napi_disable() will 224 /* There is no race here; although napi_disable() will