aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/sfc/falcon.c23
-rw-r--r--drivers/net/sfc/net_driver.h7
2 files changed, 14 insertions, 16 deletions
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c
index 34b475e9b29d..1582df7aba7b 100644
--- a/drivers/net/sfc/falcon.c
+++ b/drivers/net/sfc/falcon.c
@@ -35,19 +35,12 @@
35 35
36/** 36/**
37 * struct falcon_nic_data - Falcon NIC state 37 * struct falcon_nic_data - Falcon NIC state
38 * @next_buffer_table: First available buffer table id
39 * @pci_dev2: The secondary PCI device if present 38 * @pci_dev2: The secondary PCI device if present
40 * @i2c_data: Operations and state for I2C bit-bashing algorithm 39 * @i2c_data: Operations and state for I2C bit-bashing algorithm
41 * @int_error_count: Number of internal errors seen recently
42 * @int_error_expire: Time at which error count will be expired
43 */ 40 */
44struct falcon_nic_data { 41struct falcon_nic_data {
45 unsigned next_buffer_table;
46 struct pci_dev *pci_dev2; 42 struct pci_dev *pci_dev2;
47 struct i2c_algo_bit_data i2c_data; 43 struct i2c_algo_bit_data i2c_data;
48
49 unsigned int_error_count;
50 unsigned long int_error_expire;
51}; 44};
52 45
53/************************************************************************** 46/**************************************************************************
@@ -304,8 +297,6 @@ static int falcon_alloc_special_buffer(struct efx_nic *efx,
304 struct efx_special_buffer *buffer, 297 struct efx_special_buffer *buffer,
305 unsigned int len) 298 unsigned int len)
306{ 299{
307 struct falcon_nic_data *nic_data = efx->nic_data;
308
309 len = ALIGN(len, FALCON_BUF_SIZE); 300 len = ALIGN(len, FALCON_BUF_SIZE);
310 301
311 buffer->addr = pci_alloc_consistent(efx->pci_dev, len, 302 buffer->addr = pci_alloc_consistent(efx->pci_dev, len,
@@ -320,8 +311,8 @@ static int falcon_alloc_special_buffer(struct efx_nic *efx,
320 memset(buffer->addr, 0xff, len); 311 memset(buffer->addr, 0xff, len);
321 312
322 /* Select new buffer ID */ 313 /* Select new buffer ID */
323 buffer->index = nic_data->next_buffer_table; 314 buffer->index = efx->next_buffer_table;
324 nic_data->next_buffer_table += buffer->entries; 315 efx->next_buffer_table += buffer->entries;
325 316
326 EFX_LOG(efx, "allocating special buffers %d-%d at %llx+%x " 317 EFX_LOG(efx, "allocating special buffers %d-%d at %llx+%x "
327 "(virt %p phys %llx)\n", buffer->index, 318 "(virt %p phys %llx)\n", buffer->index,
@@ -1411,13 +1402,13 @@ static irqreturn_t falcon_fatal_interrupt(struct efx_nic *efx)
1411 falcon_disable_interrupts(efx); 1402 falcon_disable_interrupts(efx);
1412 1403
1413 /* Count errors and reset or disable the NIC accordingly */ 1404 /* Count errors and reset or disable the NIC accordingly */
1414 if (nic_data->int_error_count == 0 || 1405 if (efx->int_error_count == 0 ||
1415 time_after(jiffies, nic_data->int_error_expire)) { 1406 time_after(jiffies, efx->int_error_expire)) {
1416 nic_data->int_error_count = 0; 1407 efx->int_error_count = 0;
1417 nic_data->int_error_expire = 1408 efx->int_error_expire =
1418 jiffies + FALCON_INT_ERROR_EXPIRE * HZ; 1409 jiffies + FALCON_INT_ERROR_EXPIRE * HZ;
1419 } 1410 }
1420 if (++nic_data->int_error_count < FALCON_MAX_INT_ERRORS) { 1411 if (++efx->int_error_count < FALCON_MAX_INT_ERRORS) {
1421 EFX_ERR(efx, "SYSTEM ERROR - reset scheduled\n"); 1412 EFX_ERR(efx, "SYSTEM ERROR - reset scheduled\n");
1422 efx_schedule_reset(efx, RESET_TYPE_INT_ERROR); 1413 efx_schedule_reset(efx, RESET_TYPE_INT_ERROR);
1423 } else { 1414 } else {
diff --git a/drivers/net/sfc/net_driver.h b/drivers/net/sfc/net_driver.h
index 8e7b854c11aa..25b793327c1b 100644
--- a/drivers/net/sfc/net_driver.h
+++ b/drivers/net/sfc/net_driver.h
@@ -688,10 +688,13 @@ union efx_multicast_hash {
688 * @tx_queue: TX DMA queues 688 * @tx_queue: TX DMA queues
689 * @rx_queue: RX DMA queues 689 * @rx_queue: RX DMA queues
690 * @channel: Channels 690 * @channel: Channels
691 * @next_buffer_table: First available buffer table id
691 * @n_rx_queues: Number of RX queues 692 * @n_rx_queues: Number of RX queues
692 * @n_channels: Number of channels in use 693 * @n_channels: Number of channels in use
693 * @rx_buffer_len: RX buffer length 694 * @rx_buffer_len: RX buffer length
694 * @rx_buffer_order: Order (log2) of number of pages for each RX buffer 695 * @rx_buffer_order: Order (log2) of number of pages for each RX buffer
696 * @int_error_count: Number of internal errors seen recently
697 * @int_error_expire: Time at which error count will be expired
695 * @irq_status: Interrupt status buffer 698 * @irq_status: Interrupt status buffer
696 * @last_irq_cpu: Last CPU to handle interrupt. 699 * @last_irq_cpu: Last CPU to handle interrupt.
697 * This register is written with the SMP processor ID whenever an 700 * This register is written with the SMP processor ID whenever an
@@ -775,11 +778,15 @@ struct efx_nic {
775 struct efx_rx_queue rx_queue[EFX_MAX_RX_QUEUES]; 778 struct efx_rx_queue rx_queue[EFX_MAX_RX_QUEUES];
776 struct efx_channel channel[EFX_MAX_CHANNELS]; 779 struct efx_channel channel[EFX_MAX_CHANNELS];
777 780
781 unsigned next_buffer_table;
778 int n_rx_queues; 782 int n_rx_queues;
779 int n_channels; 783 int n_channels;
780 unsigned int rx_buffer_len; 784 unsigned int rx_buffer_len;
781 unsigned int rx_buffer_order; 785 unsigned int rx_buffer_order;
782 786
787 unsigned int_error_count;
788 unsigned long int_error_expire;
789
783 struct efx_buffer irq_status; 790 struct efx_buffer irq_status;
784 volatile signed int last_irq_cpu; 791 volatile signed int last_irq_cpu;
785 792