aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/sfc/efx.c16
-rw-r--r--drivers/net/sfc/falcon.c8
-rw-r--r--drivers/net/sfc/net_driver.h11
-rw-r--r--drivers/net/sfc/selftest.c44
4 files changed, 12 insertions, 67 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c
index 487df9499c35..2deac7b04282 100644
--- a/drivers/net/sfc/efx.c
+++ b/drivers/net/sfc/efx.c
@@ -259,7 +259,7 @@ void efx_process_channel_now(struct efx_channel *channel)
259 falcon_disable_interrupts(efx); 259 falcon_disable_interrupts(efx);
260 if (efx->legacy_irq) 260 if (efx->legacy_irq)
261 synchronize_irq(efx->legacy_irq); 261 synchronize_irq(efx->legacy_irq);
262 if (channel->has_interrupt && channel->irq) 262 if (channel->irq)
263 synchronize_irq(channel->irq); 263 synchronize_irq(channel->irq);
264 264
265 /* Wait for any NAPI processing to complete */ 265 /* Wait for any NAPI processing to complete */
@@ -872,10 +872,8 @@ static void efx_probe_interrupts(struct efx_nic *efx)
872 } 872 }
873 873
874 if (rc == 0) { 874 if (rc == 0) {
875 for (i = 0; i < efx->rss_queues; i++) { 875 for (i = 0; i < efx->rss_queues; i++)
876 efx->channel[i].has_interrupt = true;
877 efx->channel[i].irq = xentries[i].vector; 876 efx->channel[i].irq = xentries[i].vector;
878 }
879 } else { 877 } else {
880 /* Fall back to single channel MSI */ 878 /* Fall back to single channel MSI */
881 efx->interrupt_mode = EFX_INT_MODE_MSI; 879 efx->interrupt_mode = EFX_INT_MODE_MSI;
@@ -889,7 +887,6 @@ static void efx_probe_interrupts(struct efx_nic *efx)
889 rc = pci_enable_msi(efx->pci_dev); 887 rc = pci_enable_msi(efx->pci_dev);
890 if (rc == 0) { 888 if (rc == 0) {
891 efx->channel[0].irq = efx->pci_dev->irq; 889 efx->channel[0].irq = efx->pci_dev->irq;
892 efx->channel[0].has_interrupt = true;
893 } else { 890 } else {
894 EFX_ERR(efx, "could not enable MSI\n"); 891 EFX_ERR(efx, "could not enable MSI\n");
895 efx->interrupt_mode = EFX_INT_MODE_LEGACY; 892 efx->interrupt_mode = EFX_INT_MODE_LEGACY;
@@ -899,9 +896,6 @@ static void efx_probe_interrupts(struct efx_nic *efx)
899 /* Assume legacy interrupts */ 896 /* Assume legacy interrupts */
900 if (efx->interrupt_mode == EFX_INT_MODE_LEGACY) { 897 if (efx->interrupt_mode == EFX_INT_MODE_LEGACY) {
901 efx->rss_queues = 1; 898 efx->rss_queues = 1;
902 /* Every channel is interruptible */
903 for (i = 0; i < EFX_MAX_CHANNELS; i++)
904 efx->channel[i].has_interrupt = true;
905 efx->legacy_irq = efx->pci_dev->irq; 899 efx->legacy_irq = efx->pci_dev->irq;
906 } 900 }
907} 901}
@@ -911,7 +905,7 @@ static void efx_remove_interrupts(struct efx_nic *efx)
911 struct efx_channel *channel; 905 struct efx_channel *channel;
912 906
913 /* Remove MSI/MSI-X interrupts */ 907 /* Remove MSI/MSI-X interrupts */
914 efx_for_each_channel_with_interrupt(channel, efx) 908 efx_for_each_channel(channel, efx)
915 channel->irq = 0; 909 channel->irq = 0;
916 pci_disable_msi(efx->pci_dev); 910 pci_disable_msi(efx->pci_dev);
917 pci_disable_msix(efx->pci_dev); 911 pci_disable_msix(efx->pci_dev);
@@ -1106,7 +1100,7 @@ static void efx_stop_all(struct efx_nic *efx)
1106 falcon_disable_interrupts(efx); 1100 falcon_disable_interrupts(efx);
1107 if (efx->legacy_irq) 1101 if (efx->legacy_irq)
1108 synchronize_irq(efx->legacy_irq); 1102 synchronize_irq(efx->legacy_irq);
1109 efx_for_each_channel_with_interrupt(channel, efx) { 1103 efx_for_each_channel(channel, efx) {
1110 if (channel->irq) 1104 if (channel->irq)
1111 synchronize_irq(channel->irq); 1105 synchronize_irq(channel->irq);
1112 } 1106 }
@@ -1303,7 +1297,7 @@ static void efx_netpoll(struct net_device *net_dev)
1303 struct efx_nic *efx = netdev_priv(net_dev); 1297 struct efx_nic *efx = netdev_priv(net_dev);
1304 struct efx_channel *channel; 1298 struct efx_channel *channel;
1305 1299
1306 efx_for_each_channel_with_interrupt(channel, efx) 1300 efx_for_each_channel(channel, efx)
1307 efx_schedule_channel(channel); 1301 efx_schedule_channel(channel);
1308} 1302}
1309 1303
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 30176390481c..40dd643e930d 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -1317,7 +1317,7 @@ void falcon_enable_interrupts(struct efx_nic *efx)
1317 1317
1318 /* Force processing of all the channels to get the EVQ RPTRs up to 1318 /* Force processing of all the channels to get the EVQ RPTRs up to
1319 date */ 1319 date */
1320 efx_for_each_channel_with_interrupt(channel, efx) 1320 efx_for_each_channel(channel, efx)
1321 efx_schedule_channel(channel); 1321 efx_schedule_channel(channel);
1322} 1322}
1323 1323
@@ -1567,7 +1567,7 @@ int falcon_init_interrupt(struct efx_nic *efx)
1567 } 1567 }
1568 1568
1569 /* Hook MSI or MSI-X interrupt */ 1569 /* Hook MSI or MSI-X interrupt */
1570 efx_for_each_channel_with_interrupt(channel, efx) { 1570 efx_for_each_channel(channel, efx) {
1571 rc = request_irq(channel->irq, falcon_msi_interrupt, 1571 rc = request_irq(channel->irq, falcon_msi_interrupt,
1572 IRQF_PROBE_SHARED, /* Not shared */ 1572 IRQF_PROBE_SHARED, /* Not shared */
1573 efx->name, channel); 1573 efx->name, channel);
@@ -1580,7 +1580,7 @@ int falcon_init_interrupt(struct efx_nic *efx)
1580 return 0; 1580 return 0;
1581 1581
1582 fail2: 1582 fail2:
1583 efx_for_each_channel_with_interrupt(channel, efx) 1583 efx_for_each_channel(channel, efx)
1584 free_irq(channel->irq, channel); 1584 free_irq(channel->irq, channel);
1585 fail1: 1585 fail1:
1586 return rc; 1586 return rc;
@@ -1592,7 +1592,7 @@ void falcon_fini_interrupt(struct efx_nic *efx)
1592 efx_oword_t reg; 1592 efx_oword_t reg;
1593 1593
1594 /* Disable MSI/MSI-X interrupts */ 1594 /* Disable MSI/MSI-X interrupts */
1595 efx_for_each_channel_with_interrupt(channel, efx) { 1595 efx_for_each_channel(channel, efx) {
1596 if (channel->irq) 1596 if (channel->irq)
1597 free_irq(channel->irq, channel); 1597 free_irq(channel->irq, channel);
1598 } 1598 }
diff --git a/drivers/net/sfc/net_driver.h b/drivers/net/sfc/net_driver.h
index 390275710ef4..1fa134ab8eb8 100644
--- a/drivers/net/sfc/net_driver.h
+++ b/drivers/net/sfc/net_driver.h
@@ -329,7 +329,6 @@ enum efx_rx_alloc_method {
329 * @used_flags: Channel is used by net driver 329 * @used_flags: Channel is used by net driver
330 * @enabled: Channel enabled indicator 330 * @enabled: Channel enabled indicator
331 * @irq: IRQ number (MSI and MSI-X only) 331 * @irq: IRQ number (MSI and MSI-X only)
332 * @has_interrupt: Channel has an interrupt
333 * @irq_moderation: IRQ moderation value (in us) 332 * @irq_moderation: IRQ moderation value (in us)
334 * @napi_dev: Net device used with NAPI 333 * @napi_dev: Net device used with NAPI
335 * @napi_str: NAPI control structure 334 * @napi_str: NAPI control structure
@@ -361,7 +360,6 @@ struct efx_channel {
361 int used_flags; 360 int used_flags;
362 bool enabled; 361 bool enabled;
363 int irq; 362 int irq;
364 bool has_interrupt;
365 unsigned int irq_moderation; 363 unsigned int irq_moderation;
366 struct net_device *napi_dev; 364 struct net_device *napi_dev;
367 struct napi_struct napi_str; 365 struct napi_struct napi_str;
@@ -834,15 +832,6 @@ struct efx_nic_type {
834 continue; \ 832 continue; \
835 else 833 else
836 834
837/* Iterate over all used channels with interrupts */
838#define efx_for_each_channel_with_interrupt(_channel, _efx) \
839 for (_channel = &_efx->channel[0]; \
840 _channel < &_efx->channel[EFX_MAX_CHANNELS]; \
841 _channel++) \
842 if (!(_channel->used_flags && _channel->has_interrupt)) \
843 continue; \
844 else
845
846/* Iterate over all used TX queues */ 835/* Iterate over all used TX queues */
847#define efx_for_each_tx_queue(_tx_queue, _efx) \ 836#define efx_for_each_tx_queue(_tx_queue, _efx) \
848 for (_tx_queue = &_efx->tx_queue[0]; \ 837 for (_tx_queue = &_efx->tx_queue[0]; \
diff --git a/drivers/net/sfc/selftest.c b/drivers/net/sfc/selftest.c
index ff7b84c3fcfb..2f7def657679 100644
--- a/drivers/net/sfc/selftest.c
+++ b/drivers/net/sfc/selftest.c
@@ -111,7 +111,7 @@ static int efx_test_interrupts(struct efx_nic *efx,
111 111
112 /* ACK each interrupting event queue. Receiving an interrupt due to 112 /* ACK each interrupting event queue. Receiving an interrupt due to
113 * traffic before a test event is raised is considered a pass */ 113 * traffic before a test event is raised is considered a pass */
114 efx_for_each_channel_with_interrupt(channel, efx) { 114 efx_for_each_channel(channel, efx) {
115 if (channel->work_pending) 115 if (channel->work_pending)
116 efx_process_channel_now(channel); 116 efx_process_channel_now(channel);
117 if (efx->last_irq_cpu >= 0) 117 if (efx->last_irq_cpu >= 0)
@@ -136,41 +136,6 @@ static int efx_test_interrupts(struct efx_nic *efx,
136 return 0; 136 return 0;
137} 137}
138 138
139/* Test generation and receipt of non-interrupting events */
140static int efx_test_eventq(struct efx_channel *channel,
141 struct efx_self_tests *tests)
142{
143 unsigned int magic;
144
145 /* Channel specific code, limited to 20 bits */
146 magic = (0x00010150 + channel->channel);
147 EFX_LOG(channel->efx, "channel %d testing event queue with code %x\n",
148 channel->channel, magic);
149
150 tests->eventq_dma[channel->channel] = -1;
151 tests->eventq_int[channel->channel] = 1; /* fake pass */
152 tests->eventq_poll[channel->channel] = 1; /* fake pass */
153
154 /* Reset flag and zero magic word */
155 channel->efx->last_irq_cpu = -1;
156 channel->eventq_magic = 0;
157 smp_wmb();
158
159 falcon_generate_test_event(channel, magic);
160 udelay(1);
161
162 efx_process_channel_now(channel);
163 if (channel->eventq_magic != magic) {
164 EFX_ERR(channel->efx, "channel %d failed to see test event\n",
165 channel->channel);
166 return -ETIMEDOUT;
167 } else {
168 tests->eventq_dma[channel->channel] = 1;
169 }
170
171 return 0;
172}
173
174/* Test generation and receipt of interrupting events */ 139/* Test generation and receipt of interrupting events */
175static int efx_test_eventq_irq(struct efx_channel *channel, 140static int efx_test_eventq_irq(struct efx_channel *channel,
176 struct efx_self_tests *tests) 141 struct efx_self_tests *tests)
@@ -456,7 +421,7 @@ static int efx_poll_loopback(struct efx_nic *efx)
456 421
457 /* NAPI polling is not enabled, so process channels 422 /* NAPI polling is not enabled, so process channels
458 * synchronously */ 423 * synchronously */
459 efx_for_each_channel_with_interrupt(channel, efx) { 424 efx_for_each_channel(channel, efx) {
460 if (channel->work_pending) 425 if (channel->work_pending)
461 efx_process_channel_now(channel); 426 efx_process_channel_now(channel);
462 } 427 }
@@ -689,10 +654,7 @@ int efx_online_test(struct efx_nic *efx, struct efx_self_tests *tests)
689 if (rc) 654 if (rc)
690 return rc; 655 return rc;
691 efx_for_each_channel(channel, efx) { 656 efx_for_each_channel(channel, efx) {
692 if (channel->has_interrupt) 657 rc = efx_test_eventq_irq(channel, tests);
693 rc = efx_test_eventq_irq(channel, tests);
694 else
695 rc = efx_test_eventq(channel, tests);
696 if (rc) 658 if (rc)
697 return rc; 659 return rc;
698 } 660 }