aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/sfc/falcon.c26
1 files changed, 14 insertions, 12 deletions
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 2ae51fd6f9c1..92ea6147b3f2 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -1435,6 +1435,7 @@ static irqreturn_t falcon_legacy_interrupt_b0(int irq, void *dev_id)
1435{ 1435{
1436 struct efx_nic *efx = dev_id; 1436 struct efx_nic *efx = dev_id;
1437 efx_oword_t *int_ker = efx->irq_status.addr; 1437 efx_oword_t *int_ker = efx->irq_status.addr;
1438 irqreturn_t result = IRQ_NONE;
1438 struct efx_channel *channel; 1439 struct efx_channel *channel;
1439 efx_dword_t reg; 1440 efx_dword_t reg;
1440 u32 queues; 1441 u32 queues;
@@ -1449,23 +1450,24 @@ static irqreturn_t falcon_legacy_interrupt_b0(int irq, void *dev_id)
1449 if (unlikely(syserr)) 1450 if (unlikely(syserr))
1450 return falcon_fatal_interrupt(efx); 1451 return falcon_fatal_interrupt(efx);
1451 1452
1452 if (queues == 0)
1453 return IRQ_NONE;
1454
1455 efx->last_irq_cpu = raw_smp_processor_id();
1456 EFX_TRACE(efx, "IRQ %d on CPU %d status " EFX_DWORD_FMT "\n",
1457 irq, raw_smp_processor_id(), EFX_DWORD_VAL(reg));
1458
1459 /* Schedule processing of any interrupting queues */ 1453 /* Schedule processing of any interrupting queues */
1460 channel = &efx->channel[0]; 1454 efx_for_each_channel(channel, efx) {
1461 while (queues) { 1455 if ((queues & 1) ||
1462 if (queues & 0x01) 1456 falcon_event_present(
1457 falcon_event(channel, channel->eventq_read_ptr))) {
1463 efx_schedule_channel(channel); 1458 efx_schedule_channel(channel);
1464 channel++; 1459 result = IRQ_HANDLED;
1460 }
1465 queues >>= 1; 1461 queues >>= 1;
1466 } 1462 }
1467 1463
1468 return IRQ_HANDLED; 1464 if (result == IRQ_HANDLED) {
1465 efx->last_irq_cpu = raw_smp_processor_id();
1466 EFX_TRACE(efx, "IRQ %d on CPU %d status " EFX_DWORD_FMT "\n",
1467 irq, raw_smp_processor_id(), EFX_DWORD_VAL(reg));
1468 }
1469
1470 return result;
1469} 1471}
1470 1472
1471 1473