diff options
author | Ben Hutchings <bhutchings@solarflare.com> | 2009-11-28 22:43:56 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-11-29 19:46:32 -0500 |
commit | 152b6a62aea2d43359dd37004e9c218bf7bdeb3b (patch) | |
tree | fe7361364a94322a713d6b06cc6d0d7513d55c72 /drivers/net/sfc/falcon.c | |
parent | 06629f07248b259e08a6e4089fbe6aa3f98dfbe6 (diff) |
sfc: Separate shared NIC code from Falcon-specific and rename accordingly
Signed-off-by: Ben Hutchings <bhutchings@solarflare.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc/falcon.c')
-rw-r--r-- | drivers/net/sfc/falcon.c | 507 |
1 files changed, 259 insertions, 248 deletions
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c index 61cc9948b233..2e4c71114630 100644 --- a/drivers/net/sfc/falcon.c +++ b/drivers/net/sfc/falcon.c | |||
@@ -69,8 +69,8 @@ default_flash_type = ((17 << SPI_DEV_TYPE_SIZE_LBN) | |||
69 | * watermark send XOFF. Only used if RX flow control is enabled (ethtool -A) | 69 | * watermark send XOFF. Only used if RX flow control is enabled (ethtool -A) |
70 | * This also has an effect on RX/TX arbitration | 70 | * This also has an effect on RX/TX arbitration |
71 | */ | 71 | */ |
72 | static int rx_xoff_thresh_bytes = -1; | 72 | int efx_nic_rx_xoff_thresh = -1; |
73 | module_param(rx_xoff_thresh_bytes, int, 0644); | 73 | module_param_named(rx_xoff_thresh_bytes, efx_nic_rx_xoff_thresh, int, 0644); |
74 | MODULE_PARM_DESC(rx_xoff_thresh_bytes, "RX fifo XOFF threshold"); | 74 | MODULE_PARM_DESC(rx_xoff_thresh_bytes, "RX fifo XOFF threshold"); |
75 | 75 | ||
76 | /* RX FIFO XON watermark | 76 | /* RX FIFO XON watermark |
@@ -79,21 +79,21 @@ MODULE_PARM_DESC(rx_xoff_thresh_bytes, "RX fifo XOFF threshold"); | |||
79 | * watermark send XON. Only used if TX flow control is enabled (ethtool -A) | 79 | * watermark send XON. Only used if TX flow control is enabled (ethtool -A) |
80 | * This also has an effect on RX/TX arbitration | 80 | * This also has an effect on RX/TX arbitration |
81 | */ | 81 | */ |
82 | static int rx_xon_thresh_bytes = -1; | 82 | int efx_nic_rx_xon_thresh = -1; |
83 | module_param(rx_xon_thresh_bytes, int, 0644); | 83 | module_param_named(rx_xon_thresh_bytes, efx_nic_rx_xon_thresh, int, 0644); |
84 | MODULE_PARM_DESC(rx_xon_thresh_bytes, "RX fifo XON threshold"); | 84 | MODULE_PARM_DESC(rx_xon_thresh_bytes, "RX fifo XON threshold"); |
85 | 85 | ||
86 | /* If FALCON_MAX_INT_ERRORS internal errors occur within | 86 | /* If EFX_MAX_INT_ERRORS internal errors occur within |
87 | * FALCON_INT_ERROR_EXPIRE seconds, we consider the NIC broken and | 87 | * EFX_INT_ERROR_EXPIRE seconds, we consider the NIC broken and |
88 | * disable it. | 88 | * disable it. |
89 | */ | 89 | */ |
90 | #define FALCON_INT_ERROR_EXPIRE 3600 | 90 | #define EFX_INT_ERROR_EXPIRE 3600 |
91 | #define FALCON_MAX_INT_ERRORS 5 | 91 | #define EFX_MAX_INT_ERRORS 5 |
92 | 92 | ||
93 | /* We poll for events every FLUSH_INTERVAL ms, and check FLUSH_POLL_COUNT times | 93 | /* We poll for events every FLUSH_INTERVAL ms, and check FLUSH_POLL_COUNT times |
94 | */ | 94 | */ |
95 | #define FALCON_FLUSH_INTERVAL 10 | 95 | #define EFX_FLUSH_INTERVAL 10 |
96 | #define FALCON_FLUSH_POLL_COUNT 100 | 96 | #define EFX_FLUSH_POLL_COUNT 100 |
97 | 97 | ||
98 | /************************************************************************** | 98 | /************************************************************************** |
99 | * | 99 | * |
@@ -103,30 +103,27 @@ MODULE_PARM_DESC(rx_xon_thresh_bytes, "RX fifo XON threshold"); | |||
103 | */ | 103 | */ |
104 | 104 | ||
105 | /* Size and alignment of special buffers (4KB) */ | 105 | /* Size and alignment of special buffers (4KB) */ |
106 | #define FALCON_BUF_SIZE 4096 | 106 | #define EFX_BUF_SIZE 4096 |
107 | 107 | ||
108 | /* Depth of RX flush request fifo */ | 108 | /* Depth of RX flush request fifo */ |
109 | #define FALCON_RX_FLUSH_COUNT 4 | 109 | #define EFX_RX_FLUSH_COUNT 4 |
110 | |||
111 | #define FALCON_IS_DUAL_FUNC(efx) \ | ||
112 | (efx_nic_rev(efx) < EFX_REV_FALCON_B0) | ||
113 | 110 | ||
114 | /************************************************************************** | 111 | /************************************************************************** |
115 | * | 112 | * |
116 | * Falcon hardware access | 113 | * Solarstorm hardware access |
117 | * | 114 | * |
118 | **************************************************************************/ | 115 | **************************************************************************/ |
119 | 116 | ||
120 | static inline void falcon_write_buf_tbl(struct efx_nic *efx, efx_qword_t *value, | 117 | static inline void efx_write_buf_tbl(struct efx_nic *efx, efx_qword_t *value, |
121 | unsigned int index) | 118 | unsigned int index) |
122 | { | 119 | { |
123 | efx_sram_writeq(efx, efx->membase + efx->type->buf_tbl_base, | 120 | efx_sram_writeq(efx, efx->membase + efx->type->buf_tbl_base, |
124 | value, index); | 121 | value, index); |
125 | } | 122 | } |
126 | 123 | ||
127 | /* Read the current event from the event queue */ | 124 | /* Read the current event from the event queue */ |
128 | static inline efx_qword_t *falcon_event(struct efx_channel *channel, | 125 | static inline efx_qword_t *efx_event(struct efx_channel *channel, |
129 | unsigned int index) | 126 | unsigned int index) |
130 | { | 127 | { |
131 | return (((efx_qword_t *) (channel->eventq.addr)) + index); | 128 | return (((efx_qword_t *) (channel->eventq.addr)) + index); |
132 | } | 129 | } |
@@ -141,7 +138,7 @@ static inline efx_qword_t *falcon_event(struct efx_channel *channel, | |||
141 | * Note that using a single 64-bit comparison is incorrect; even | 138 | * Note that using a single 64-bit comparison is incorrect; even |
142 | * though the CPU read will be atomic, the DMA write may not be. | 139 | * though the CPU read will be atomic, the DMA write may not be. |
143 | */ | 140 | */ |
144 | static inline int falcon_event_present(efx_qword_t *event) | 141 | static inline int efx_event_present(efx_qword_t *event) |
145 | { | 142 | { |
146 | return (!(EFX_DWORD_IS_ALL_ONES(event->dword[0]) | | 143 | return (!(EFX_DWORD_IS_ALL_ONES(event->dword[0]) | |
147 | EFX_DWORD_IS_ALL_ONES(event->dword[1]))); | 144 | EFX_DWORD_IS_ALL_ONES(event->dword[1]))); |
@@ -205,22 +202,21 @@ static struct i2c_algo_bit_data falcon_i2c_bit_operations = { | |||
205 | 202 | ||
206 | /************************************************************************** | 203 | /************************************************************************** |
207 | * | 204 | * |
208 | * Falcon special buffer handling | 205 | * Special buffer handling |
209 | * Special buffers are used for event queues and the TX and RX | 206 | * Special buffers are used for event queues and the TX and RX |
210 | * descriptor rings. | 207 | * descriptor rings. |
211 | * | 208 | * |
212 | *************************************************************************/ | 209 | *************************************************************************/ |
213 | 210 | ||
214 | /* | 211 | /* |
215 | * Initialise a Falcon special buffer | 212 | * Initialise a special buffer |
216 | * | 213 | * |
217 | * This will define a buffer (previously allocated via | 214 | * This will define a buffer (previously allocated via |
218 | * falcon_alloc_special_buffer()) in Falcon's buffer table, allowing | 215 | * efx_alloc_special_buffer()) in the buffer table, allowing |
219 | * it to be used for event queues, descriptor rings etc. | 216 | * it to be used for event queues, descriptor rings etc. |
220 | */ | 217 | */ |
221 | static void | 218 | static void |
222 | falcon_init_special_buffer(struct efx_nic *efx, | 219 | efx_init_special_buffer(struct efx_nic *efx, struct efx_special_buffer *buffer) |
223 | struct efx_special_buffer *buffer) | ||
224 | { | 220 | { |
225 | efx_qword_t buf_desc; | 221 | efx_qword_t buf_desc; |
226 | int index; | 222 | int index; |
@@ -239,14 +235,13 @@ falcon_init_special_buffer(struct efx_nic *efx, | |||
239 | FRF_AZ_BUF_ADR_REGION, 0, | 235 | FRF_AZ_BUF_ADR_REGION, 0, |
240 | FRF_AZ_BUF_ADR_FBUF, dma_addr >> 12, | 236 | FRF_AZ_BUF_ADR_FBUF, dma_addr >> 12, |
241 | FRF_AZ_BUF_OWNER_ID_FBUF, 0); | 237 | FRF_AZ_BUF_OWNER_ID_FBUF, 0); |
242 | falcon_write_buf_tbl(efx, &buf_desc, index); | 238 | efx_write_buf_tbl(efx, &buf_desc, index); |
243 | } | 239 | } |
244 | } | 240 | } |
245 | 241 | ||
246 | /* Unmaps a buffer from Falcon and clears the buffer table entries */ | 242 | /* Unmaps a buffer and clears the buffer table entries */ |
247 | static void | 243 | static void |
248 | falcon_fini_special_buffer(struct efx_nic *efx, | 244 | efx_fini_special_buffer(struct efx_nic *efx, struct efx_special_buffer *buffer) |
249 | struct efx_special_buffer *buffer) | ||
250 | { | 245 | { |
251 | efx_oword_t buf_tbl_upd; | 246 | efx_oword_t buf_tbl_upd; |
252 | unsigned int start = buffer->index; | 247 | unsigned int start = buffer->index; |
@@ -267,27 +262,27 @@ falcon_fini_special_buffer(struct efx_nic *efx, | |||
267 | } | 262 | } |
268 | 263 | ||
269 | /* | 264 | /* |
270 | * Allocate a new Falcon special buffer | 265 | * Allocate a new special buffer |
271 | * | 266 | * |
272 | * This allocates memory for a new buffer, clears it and allocates a | 267 | * This allocates memory for a new buffer, clears it and allocates a |
273 | * new buffer ID range. It does not write into Falcon's buffer table. | 268 | * new buffer ID range. It does not write into the buffer table. |
274 | * | 269 | * |
275 | * This call will allocate 4KB buffers, since Falcon can't use 8KB | 270 | * This call will allocate 4KB buffers, since 8KB buffers can't be |
276 | * buffers for event queues and descriptor rings. | 271 | * used for event queues and descriptor rings. |
277 | */ | 272 | */ |
278 | static int falcon_alloc_special_buffer(struct efx_nic *efx, | 273 | static int efx_alloc_special_buffer(struct efx_nic *efx, |
279 | struct efx_special_buffer *buffer, | 274 | struct efx_special_buffer *buffer, |
280 | unsigned int len) | 275 | unsigned int len) |
281 | { | 276 | { |
282 | len = ALIGN(len, FALCON_BUF_SIZE); | 277 | len = ALIGN(len, EFX_BUF_SIZE); |
283 | 278 | ||
284 | buffer->addr = pci_alloc_consistent(efx->pci_dev, len, | 279 | buffer->addr = pci_alloc_consistent(efx->pci_dev, len, |
285 | &buffer->dma_addr); | 280 | &buffer->dma_addr); |
286 | if (!buffer->addr) | 281 | if (!buffer->addr) |
287 | return -ENOMEM; | 282 | return -ENOMEM; |
288 | buffer->len = len; | 283 | buffer->len = len; |
289 | buffer->entries = len / FALCON_BUF_SIZE; | 284 | buffer->entries = len / EFX_BUF_SIZE; |
290 | BUG_ON(buffer->dma_addr & (FALCON_BUF_SIZE - 1)); | 285 | BUG_ON(buffer->dma_addr & (EFX_BUF_SIZE - 1)); |
291 | 286 | ||
292 | /* All zeros is a potentially valid event so memset to 0xff */ | 287 | /* All zeros is a potentially valid event so memset to 0xff */ |
293 | memset(buffer->addr, 0xff, len); | 288 | memset(buffer->addr, 0xff, len); |
@@ -305,8 +300,8 @@ static int falcon_alloc_special_buffer(struct efx_nic *efx, | |||
305 | return 0; | 300 | return 0; |
306 | } | 301 | } |
307 | 302 | ||
308 | static void falcon_free_special_buffer(struct efx_nic *efx, | 303 | static void |
309 | struct efx_special_buffer *buffer) | 304 | efx_free_special_buffer(struct efx_nic *efx, struct efx_special_buffer *buffer) |
310 | { | 305 | { |
311 | if (!buffer->addr) | 306 | if (!buffer->addr) |
312 | return; | 307 | return; |
@@ -325,13 +320,13 @@ static void falcon_free_special_buffer(struct efx_nic *efx, | |||
325 | 320 | ||
326 | /************************************************************************** | 321 | /************************************************************************** |
327 | * | 322 | * |
328 | * Falcon generic buffer handling | 323 | * Generic buffer handling |
329 | * These buffers are used for interrupt status and MAC stats | 324 | * These buffers are used for interrupt status and MAC stats |
330 | * | 325 | * |
331 | **************************************************************************/ | 326 | **************************************************************************/ |
332 | 327 | ||
333 | static int falcon_alloc_buffer(struct efx_nic *efx, | 328 | int efx_nic_alloc_buffer(struct efx_nic *efx, struct efx_buffer *buffer, |
334 | struct efx_buffer *buffer, unsigned int len) | 329 | unsigned int len) |
335 | { | 330 | { |
336 | buffer->addr = pci_alloc_consistent(efx->pci_dev, len, | 331 | buffer->addr = pci_alloc_consistent(efx->pci_dev, len, |
337 | &buffer->dma_addr); | 332 | &buffer->dma_addr); |
@@ -342,7 +337,7 @@ static int falcon_alloc_buffer(struct efx_nic *efx, | |||
342 | return 0; | 337 | return 0; |
343 | } | 338 | } |
344 | 339 | ||
345 | static void falcon_free_buffer(struct efx_nic *efx, struct efx_buffer *buffer) | 340 | void efx_nic_free_buffer(struct efx_nic *efx, struct efx_buffer *buffer) |
346 | { | 341 | { |
347 | if (buffer->addr) { | 342 | if (buffer->addr) { |
348 | pci_free_consistent(efx->pci_dev, buffer->len, | 343 | pci_free_consistent(efx->pci_dev, buffer->len, |
@@ -353,21 +348,21 @@ static void falcon_free_buffer(struct efx_nic *efx, struct efx_buffer *buffer) | |||
353 | 348 | ||
354 | /************************************************************************** | 349 | /************************************************************************** |
355 | * | 350 | * |
356 | * Falcon TX path | 351 | * TX path |
357 | * | 352 | * |
358 | **************************************************************************/ | 353 | **************************************************************************/ |
359 | 354 | ||
360 | /* Returns a pointer to the specified transmit descriptor in the TX | 355 | /* Returns a pointer to the specified transmit descriptor in the TX |
361 | * descriptor queue belonging to the specified channel. | 356 | * descriptor queue belonging to the specified channel. |
362 | */ | 357 | */ |
363 | static inline efx_qword_t *falcon_tx_desc(struct efx_tx_queue *tx_queue, | 358 | static inline efx_qword_t * |
364 | unsigned int index) | 359 | efx_tx_desc(struct efx_tx_queue *tx_queue, unsigned int index) |
365 | { | 360 | { |
366 | return (((efx_qword_t *) (tx_queue->txd.addr)) + index); | 361 | return (((efx_qword_t *) (tx_queue->txd.addr)) + index); |
367 | } | 362 | } |
368 | 363 | ||
369 | /* This writes to the TX_DESC_WPTR; write pointer for TX descriptor ring */ | 364 | /* This writes to the TX_DESC_WPTR; write pointer for TX descriptor ring */ |
370 | static inline void falcon_notify_tx_desc(struct efx_tx_queue *tx_queue) | 365 | static inline void efx_notify_tx_desc(struct efx_tx_queue *tx_queue) |
371 | { | 366 | { |
372 | unsigned write_ptr; | 367 | unsigned write_ptr; |
373 | efx_dword_t reg; | 368 | efx_dword_t reg; |
@@ -383,7 +378,7 @@ static inline void falcon_notify_tx_desc(struct efx_tx_queue *tx_queue) | |||
383 | * descriptor in the hardware TX descriptor ring (in host memory), and | 378 | * descriptor in the hardware TX descriptor ring (in host memory), and |
384 | * write a doorbell. | 379 | * write a doorbell. |
385 | */ | 380 | */ |
386 | void falcon_push_buffers(struct efx_tx_queue *tx_queue) | 381 | void efx_nic_push_buffers(struct efx_tx_queue *tx_queue) |
387 | { | 382 | { |
388 | 383 | ||
389 | struct efx_tx_buffer *buffer; | 384 | struct efx_tx_buffer *buffer; |
@@ -395,7 +390,7 @@ void falcon_push_buffers(struct efx_tx_queue *tx_queue) | |||
395 | do { | 390 | do { |
396 | write_ptr = tx_queue->write_count & EFX_TXQ_MASK; | 391 | write_ptr = tx_queue->write_count & EFX_TXQ_MASK; |
397 | buffer = &tx_queue->buffer[write_ptr]; | 392 | buffer = &tx_queue->buffer[write_ptr]; |
398 | txd = falcon_tx_desc(tx_queue, write_ptr); | 393 | txd = efx_tx_desc(tx_queue, write_ptr); |
399 | ++tx_queue->write_count; | 394 | ++tx_queue->write_count; |
400 | 395 | ||
401 | /* Create TX descriptor ring entry */ | 396 | /* Create TX descriptor ring entry */ |
@@ -407,20 +402,20 @@ void falcon_push_buffers(struct efx_tx_queue *tx_queue) | |||
407 | } while (tx_queue->write_count != tx_queue->insert_count); | 402 | } while (tx_queue->write_count != tx_queue->insert_count); |
408 | 403 | ||
409 | wmb(); /* Ensure descriptors are written before they are fetched */ | 404 | wmb(); /* Ensure descriptors are written before they are fetched */ |
410 | falcon_notify_tx_desc(tx_queue); | 405 | efx_notify_tx_desc(tx_queue); |
411 | } | 406 | } |
412 | 407 | ||
413 | /* Allocate hardware resources for a TX queue */ | 408 | /* Allocate hardware resources for a TX queue */ |
414 | int falcon_probe_tx(struct efx_tx_queue *tx_queue) | 409 | int efx_nic_probe_tx(struct efx_tx_queue *tx_queue) |
415 | { | 410 | { |
416 | struct efx_nic *efx = tx_queue->efx; | 411 | struct efx_nic *efx = tx_queue->efx; |
417 | BUILD_BUG_ON(EFX_TXQ_SIZE < 512 || EFX_TXQ_SIZE > 4096 || | 412 | BUILD_BUG_ON(EFX_TXQ_SIZE < 512 || EFX_TXQ_SIZE > 4096 || |
418 | EFX_TXQ_SIZE & EFX_TXQ_MASK); | 413 | EFX_TXQ_SIZE & EFX_TXQ_MASK); |
419 | return falcon_alloc_special_buffer(efx, &tx_queue->txd, | 414 | return efx_alloc_special_buffer(efx, &tx_queue->txd, |
420 | EFX_TXQ_SIZE * sizeof(efx_qword_t)); | 415 | EFX_TXQ_SIZE * sizeof(efx_qword_t)); |
421 | } | 416 | } |
422 | 417 | ||
423 | void falcon_init_tx(struct efx_tx_queue *tx_queue) | 418 | void efx_nic_init_tx(struct efx_tx_queue *tx_queue) |
424 | { | 419 | { |
425 | efx_oword_t tx_desc_ptr; | 420 | efx_oword_t tx_desc_ptr; |
426 | struct efx_nic *efx = tx_queue->efx; | 421 | struct efx_nic *efx = tx_queue->efx; |
@@ -428,7 +423,7 @@ void falcon_init_tx(struct efx_tx_queue *tx_queue) | |||
428 | tx_queue->flushed = FLUSH_NONE; | 423 | tx_queue->flushed = FLUSH_NONE; |
429 | 424 | ||
430 | /* Pin TX descriptor ring */ | 425 | /* Pin TX descriptor ring */ |
431 | falcon_init_special_buffer(efx, &tx_queue->txd); | 426 | efx_init_special_buffer(efx, &tx_queue->txd); |
432 | 427 | ||
433 | /* Push TX descriptor ring to card */ | 428 | /* Push TX descriptor ring to card */ |
434 | EFX_POPULATE_OWORD_10(tx_desc_ptr, | 429 | EFX_POPULATE_OWORD_10(tx_desc_ptr, |
@@ -470,7 +465,7 @@ void falcon_init_tx(struct efx_tx_queue *tx_queue) | |||
470 | } | 465 | } |
471 | } | 466 | } |
472 | 467 | ||
473 | static void falcon_flush_tx_queue(struct efx_tx_queue *tx_queue) | 468 | static void efx_flush_tx_queue(struct efx_tx_queue *tx_queue) |
474 | { | 469 | { |
475 | struct efx_nic *efx = tx_queue->efx; | 470 | struct efx_nic *efx = tx_queue->efx; |
476 | efx_oword_t tx_flush_descq; | 471 | efx_oword_t tx_flush_descq; |
@@ -484,7 +479,7 @@ static void falcon_flush_tx_queue(struct efx_tx_queue *tx_queue) | |||
484 | efx_writeo(efx, &tx_flush_descq, FR_AZ_TX_FLUSH_DESCQ); | 479 | efx_writeo(efx, &tx_flush_descq, FR_AZ_TX_FLUSH_DESCQ); |
485 | } | 480 | } |
486 | 481 | ||
487 | void falcon_fini_tx(struct efx_tx_queue *tx_queue) | 482 | void efx_nic_fini_tx(struct efx_tx_queue *tx_queue) |
488 | { | 483 | { |
489 | struct efx_nic *efx = tx_queue->efx; | 484 | struct efx_nic *efx = tx_queue->efx; |
490 | efx_oword_t tx_desc_ptr; | 485 | efx_oword_t tx_desc_ptr; |
@@ -498,36 +493,36 @@ void falcon_fini_tx(struct efx_tx_queue *tx_queue) | |||
498 | tx_queue->queue); | 493 | tx_queue->queue); |
499 | 494 | ||
500 | /* Unpin TX descriptor ring */ | 495 | /* Unpin TX descriptor ring */ |
501 | falcon_fini_special_buffer(efx, &tx_queue->txd); | 496 | efx_fini_special_buffer(efx, &tx_queue->txd); |
502 | } | 497 | } |
503 | 498 | ||
504 | /* Free buffers backing TX queue */ | 499 | /* Free buffers backing TX queue */ |
505 | void falcon_remove_tx(struct efx_tx_queue *tx_queue) | 500 | void efx_nic_remove_tx(struct efx_tx_queue *tx_queue) |
506 | { | 501 | { |
507 | falcon_free_special_buffer(tx_queue->efx, &tx_queue->txd); | 502 | efx_free_special_buffer(tx_queue->efx, &tx_queue->txd); |
508 | } | 503 | } |
509 | 504 | ||
510 | /************************************************************************** | 505 | /************************************************************************** |
511 | * | 506 | * |
512 | * Falcon RX path | 507 | * RX path |
513 | * | 508 | * |
514 | **************************************************************************/ | 509 | **************************************************************************/ |
515 | 510 | ||
516 | /* Returns a pointer to the specified descriptor in the RX descriptor queue */ | 511 | /* Returns a pointer to the specified descriptor in the RX descriptor queue */ |
517 | static inline efx_qword_t *falcon_rx_desc(struct efx_rx_queue *rx_queue, | 512 | static inline efx_qword_t * |
518 | unsigned int index) | 513 | efx_rx_desc(struct efx_rx_queue *rx_queue, unsigned int index) |
519 | { | 514 | { |
520 | return (((efx_qword_t *) (rx_queue->rxd.addr)) + index); | 515 | return (((efx_qword_t *) (rx_queue->rxd.addr)) + index); |
521 | } | 516 | } |
522 | 517 | ||
523 | /* This creates an entry in the RX descriptor queue */ | 518 | /* This creates an entry in the RX descriptor queue */ |
524 | static inline void falcon_build_rx_desc(struct efx_rx_queue *rx_queue, | 519 | static inline void |
525 | unsigned index) | 520 | efx_build_rx_desc(struct efx_rx_queue *rx_queue, unsigned index) |
526 | { | 521 | { |
527 | struct efx_rx_buffer *rx_buf; | 522 | struct efx_rx_buffer *rx_buf; |
528 | efx_qword_t *rxd; | 523 | efx_qword_t *rxd; |
529 | 524 | ||
530 | rxd = falcon_rx_desc(rx_queue, index); | 525 | rxd = efx_rx_desc(rx_queue, index); |
531 | rx_buf = efx_rx_buffer(rx_queue, index); | 526 | rx_buf = efx_rx_buffer(rx_queue, index); |
532 | EFX_POPULATE_QWORD_3(*rxd, | 527 | EFX_POPULATE_QWORD_3(*rxd, |
533 | FSF_AZ_RX_KER_BUF_SIZE, | 528 | FSF_AZ_RX_KER_BUF_SIZE, |
@@ -540,15 +535,15 @@ static inline void falcon_build_rx_desc(struct efx_rx_queue *rx_queue, | |||
540 | /* This writes to the RX_DESC_WPTR register for the specified receive | 535 | /* This writes to the RX_DESC_WPTR register for the specified receive |
541 | * descriptor ring. | 536 | * descriptor ring. |
542 | */ | 537 | */ |
543 | void falcon_notify_rx_desc(struct efx_rx_queue *rx_queue) | 538 | void efx_nic_notify_rx_desc(struct efx_rx_queue *rx_queue) |
544 | { | 539 | { |
545 | efx_dword_t reg; | 540 | efx_dword_t reg; |
546 | unsigned write_ptr; | 541 | unsigned write_ptr; |
547 | 542 | ||
548 | while (rx_queue->notified_count != rx_queue->added_count) { | 543 | while (rx_queue->notified_count != rx_queue->added_count) { |
549 | falcon_build_rx_desc(rx_queue, | 544 | efx_build_rx_desc(rx_queue, |
550 | rx_queue->notified_count & | 545 | rx_queue->notified_count & |
551 | EFX_RXQ_MASK); | 546 | EFX_RXQ_MASK); |
552 | ++rx_queue->notified_count; | 547 | ++rx_queue->notified_count; |
553 | } | 548 | } |
554 | 549 | ||
@@ -559,16 +554,16 @@ void falcon_notify_rx_desc(struct efx_rx_queue *rx_queue) | |||
559 | FR_AZ_RX_DESC_UPD_DWORD_P0, rx_queue->queue); | 554 | FR_AZ_RX_DESC_UPD_DWORD_P0, rx_queue->queue); |
560 | } | 555 | } |
561 | 556 | ||
562 | int falcon_probe_rx(struct efx_rx_queue *rx_queue) | 557 | int efx_nic_probe_rx(struct efx_rx_queue *rx_queue) |
563 | { | 558 | { |
564 | struct efx_nic *efx = rx_queue->efx; | 559 | struct efx_nic *efx = rx_queue->efx; |
565 | BUILD_BUG_ON(EFX_RXQ_SIZE < 512 || EFX_RXQ_SIZE > 4096 || | 560 | BUILD_BUG_ON(EFX_RXQ_SIZE < 512 || EFX_RXQ_SIZE > 4096 || |
566 | EFX_RXQ_SIZE & EFX_RXQ_MASK); | 561 | EFX_RXQ_SIZE & EFX_RXQ_MASK); |
567 | return falcon_alloc_special_buffer(efx, &rx_queue->rxd, | 562 | return efx_alloc_special_buffer(efx, &rx_queue->rxd, |
568 | EFX_RXQ_SIZE * sizeof(efx_qword_t)); | 563 | EFX_RXQ_SIZE * sizeof(efx_qword_t)); |
569 | } | 564 | } |
570 | 565 | ||
571 | void falcon_init_rx(struct efx_rx_queue *rx_queue) | 566 | void efx_nic_init_rx(struct efx_rx_queue *rx_queue) |
572 | { | 567 | { |
573 | efx_oword_t rx_desc_ptr; | 568 | efx_oword_t rx_desc_ptr; |
574 | struct efx_nic *efx = rx_queue->efx; | 569 | struct efx_nic *efx = rx_queue->efx; |
@@ -582,7 +577,7 @@ void falcon_init_rx(struct efx_rx_queue *rx_queue) | |||
582 | rx_queue->flushed = FLUSH_NONE; | 577 | rx_queue->flushed = FLUSH_NONE; |
583 | 578 | ||
584 | /* Pin RX descriptor ring */ | 579 | /* Pin RX descriptor ring */ |
585 | falcon_init_special_buffer(efx, &rx_queue->rxd); | 580 | efx_init_special_buffer(efx, &rx_queue->rxd); |
586 | 581 | ||
587 | /* Push RX descriptor ring to card */ | 582 | /* Push RX descriptor ring to card */ |
588 | EFX_POPULATE_OWORD_10(rx_desc_ptr, | 583 | EFX_POPULATE_OWORD_10(rx_desc_ptr, |
@@ -603,7 +598,7 @@ void falcon_init_rx(struct efx_rx_queue *rx_queue) | |||
603 | rx_queue->queue); | 598 | rx_queue->queue); |
604 | } | 599 | } |
605 | 600 | ||
606 | static void falcon_flush_rx_queue(struct efx_rx_queue *rx_queue) | 601 | static void efx_flush_rx_queue(struct efx_rx_queue *rx_queue) |
607 | { | 602 | { |
608 | struct efx_nic *efx = rx_queue->efx; | 603 | struct efx_nic *efx = rx_queue->efx; |
609 | efx_oword_t rx_flush_descq; | 604 | efx_oword_t rx_flush_descq; |
@@ -617,7 +612,7 @@ static void falcon_flush_rx_queue(struct efx_rx_queue *rx_queue) | |||
617 | efx_writeo(efx, &rx_flush_descq, FR_AZ_RX_FLUSH_DESCQ); | 612 | efx_writeo(efx, &rx_flush_descq, FR_AZ_RX_FLUSH_DESCQ); |
618 | } | 613 | } |
619 | 614 | ||
620 | void falcon_fini_rx(struct efx_rx_queue *rx_queue) | 615 | void efx_nic_fini_rx(struct efx_rx_queue *rx_queue) |
621 | { | 616 | { |
622 | efx_oword_t rx_desc_ptr; | 617 | efx_oword_t rx_desc_ptr; |
623 | struct efx_nic *efx = rx_queue->efx; | 618 | struct efx_nic *efx = rx_queue->efx; |
@@ -631,18 +626,18 @@ void falcon_fini_rx(struct efx_rx_queue *rx_queue) | |||
631 | rx_queue->queue); | 626 | rx_queue->queue); |
632 | 627 | ||
633 | /* Unpin RX descriptor ring */ | 628 | /* Unpin RX descriptor ring */ |
634 | falcon_fini_special_buffer(efx, &rx_queue->rxd); | 629 | efx_fini_special_buffer(efx, &rx_queue->rxd); |
635 | } | 630 | } |
636 | 631 | ||
637 | /* Free buffers backing RX queue */ | 632 | /* Free buffers backing RX queue */ |
638 | void falcon_remove_rx(struct efx_rx_queue *rx_queue) | 633 | void efx_nic_remove_rx(struct efx_rx_queue *rx_queue) |
639 | { | 634 | { |
640 | falcon_free_special_buffer(rx_queue->efx, &rx_queue->rxd); | 635 | efx_free_special_buffer(rx_queue->efx, &rx_queue->rxd); |
641 | } | 636 | } |
642 | 637 | ||
643 | /************************************************************************** | 638 | /************************************************************************** |
644 | * | 639 | * |
645 | * Falcon event queue processing | 640 | * Event queue processing |
646 | * Event queues are processed by per-channel tasklets. | 641 | * Event queues are processed by per-channel tasklets. |
647 | * | 642 | * |
648 | **************************************************************************/ | 643 | **************************************************************************/ |
@@ -656,7 +651,7 @@ void falcon_remove_rx(struct efx_rx_queue *rx_queue) | |||
656 | * whereas channel->eventq_read_ptr contains the index of the "next to | 651 | * whereas channel->eventq_read_ptr contains the index of the "next to |
657 | * read" event. | 652 | * read" event. |
658 | */ | 653 | */ |
659 | void falcon_eventq_read_ack(struct efx_channel *channel) | 654 | void efx_nic_eventq_read_ack(struct efx_channel *channel) |
660 | { | 655 | { |
661 | efx_dword_t reg; | 656 | efx_dword_t reg; |
662 | struct efx_nic *efx = channel->efx; | 657 | struct efx_nic *efx = channel->efx; |
@@ -667,7 +662,7 @@ void falcon_eventq_read_ack(struct efx_channel *channel) | |||
667 | } | 662 | } |
668 | 663 | ||
669 | /* Use HW to insert a SW defined event */ | 664 | /* Use HW to insert a SW defined event */ |
670 | void falcon_generate_event(struct efx_channel *channel, efx_qword_t *event) | 665 | void efx_generate_event(struct efx_channel *channel, efx_qword_t *event) |
671 | { | 666 | { |
672 | efx_oword_t drv_ev_reg; | 667 | efx_oword_t drv_ev_reg; |
673 | 668 | ||
@@ -683,11 +678,11 @@ void falcon_generate_event(struct efx_channel *channel, efx_qword_t *event) | |||
683 | 678 | ||
684 | /* Handle a transmit completion event | 679 | /* Handle a transmit completion event |
685 | * | 680 | * |
686 | * Falcon batches TX completion events; the message we receive is of | 681 | * The NIC batches TX completion events; the message we receive is of |
687 | * the form "complete all TX events up to this index". | 682 | * the form "complete all TX events up to this index". |
688 | */ | 683 | */ |
689 | static void falcon_handle_tx_event(struct efx_channel *channel, | 684 | static void |
690 | efx_qword_t *event) | 685 | efx_handle_tx_event(struct efx_channel *channel, efx_qword_t *event) |
691 | { | 686 | { |
692 | unsigned int tx_ev_desc_ptr; | 687 | unsigned int tx_ev_desc_ptr; |
693 | unsigned int tx_ev_q_label; | 688 | unsigned int tx_ev_q_label; |
@@ -710,7 +705,7 @@ static void falcon_handle_tx_event(struct efx_channel *channel, | |||
710 | 705 | ||
711 | if (efx_dev_registered(efx)) | 706 | if (efx_dev_registered(efx)) |
712 | netif_tx_lock(efx->net_dev); | 707 | netif_tx_lock(efx->net_dev); |
713 | falcon_notify_tx_desc(tx_queue); | 708 | efx_notify_tx_desc(tx_queue); |
714 | if (efx_dev_registered(efx)) | 709 | if (efx_dev_registered(efx)) |
715 | netif_tx_unlock(efx->net_dev); | 710 | netif_tx_unlock(efx->net_dev); |
716 | } else if (EFX_QWORD_FIELD(*event, FSF_AZ_TX_EV_PKT_ERR) && | 711 | } else if (EFX_QWORD_FIELD(*event, FSF_AZ_TX_EV_PKT_ERR) && |
@@ -724,10 +719,10 @@ static void falcon_handle_tx_event(struct efx_channel *channel, | |||
724 | } | 719 | } |
725 | 720 | ||
726 | /* Detect errors included in the rx_evt_pkt_ok bit. */ | 721 | /* Detect errors included in the rx_evt_pkt_ok bit. */ |
727 | static void falcon_handle_rx_not_ok(struct efx_rx_queue *rx_queue, | 722 | static void efx_handle_rx_not_ok(struct efx_rx_queue *rx_queue, |
728 | const efx_qword_t *event, | 723 | const efx_qword_t *event, |
729 | bool *rx_ev_pkt_ok, | 724 | bool *rx_ev_pkt_ok, |
730 | bool *discard) | 725 | bool *discard) |
731 | { | 726 | { |
732 | struct efx_nic *efx = rx_queue->efx; | 727 | struct efx_nic *efx = rx_queue->efx; |
733 | bool rx_ev_buf_owner_id_err, rx_ev_ip_hdr_chksum_err; | 728 | bool rx_ev_buf_owner_id_err, rx_ev_ip_hdr_chksum_err; |
@@ -799,8 +794,8 @@ static void falcon_handle_rx_not_ok(struct efx_rx_queue *rx_queue, | |||
799 | } | 794 | } |
800 | 795 | ||
801 | /* Handle receive events that are not in-order. */ | 796 | /* Handle receive events that are not in-order. */ |
802 | static void falcon_handle_rx_bad_index(struct efx_rx_queue *rx_queue, | 797 | static void |
803 | unsigned index) | 798 | efx_handle_rx_bad_index(struct efx_rx_queue *rx_queue, unsigned index) |
804 | { | 799 | { |
805 | struct efx_nic *efx = rx_queue->efx; | 800 | struct efx_nic *efx = rx_queue->efx; |
806 | unsigned expected, dropped; | 801 | unsigned expected, dropped; |
@@ -816,13 +811,13 @@ static void falcon_handle_rx_bad_index(struct efx_rx_queue *rx_queue, | |||
816 | 811 | ||
817 | /* Handle a packet received event | 812 | /* Handle a packet received event |
818 | * | 813 | * |
819 | * Falcon silicon gives a "discard" flag if it's a unicast packet with the | 814 | * The NIC gives a "discard" flag if it's a unicast packet with the |
820 | * wrong destination address | 815 | * wrong destination address |
821 | * Also "is multicast" and "matches multicast filter" flags can be used to | 816 | * Also "is multicast" and "matches multicast filter" flags can be used to |
822 | * discard non-matching multicast packets. | 817 | * discard non-matching multicast packets. |
823 | */ | 818 | */ |
824 | static void falcon_handle_rx_event(struct efx_channel *channel, | 819 | static void |
825 | const efx_qword_t *event) | 820 | efx_handle_rx_event(struct efx_channel *channel, const efx_qword_t *event) |
826 | { | 821 | { |
827 | unsigned int rx_ev_desc_ptr, rx_ev_byte_cnt; | 822 | unsigned int rx_ev_desc_ptr, rx_ev_byte_cnt; |
828 | unsigned int rx_ev_hdr_type, rx_ev_mcast_pkt; | 823 | unsigned int rx_ev_hdr_type, rx_ev_mcast_pkt; |
@@ -845,19 +840,18 @@ static void falcon_handle_rx_event(struct efx_channel *channel, | |||
845 | rx_ev_desc_ptr = EFX_QWORD_FIELD(*event, FSF_AZ_RX_EV_DESC_PTR); | 840 | rx_ev_desc_ptr = EFX_QWORD_FIELD(*event, FSF_AZ_RX_EV_DESC_PTR); |
846 | expected_ptr = rx_queue->removed_count & EFX_RXQ_MASK; | 841 | expected_ptr = rx_queue->removed_count & EFX_RXQ_MASK; |
847 | if (unlikely(rx_ev_desc_ptr != expected_ptr)) | 842 | if (unlikely(rx_ev_desc_ptr != expected_ptr)) |
848 | falcon_handle_rx_bad_index(rx_queue, rx_ev_desc_ptr); | 843 | efx_handle_rx_bad_index(rx_queue, rx_ev_desc_ptr); |
849 | 844 | ||
850 | if (likely(rx_ev_pkt_ok)) { | 845 | if (likely(rx_ev_pkt_ok)) { |
851 | /* If packet is marked as OK and packet type is TCP/IPv4 or | 846 | /* If packet is marked as OK and packet type is TCP/IP or |
852 | * UDP/IPv4, then we can rely on the hardware checksum. | 847 | * UDP/IP, then we can rely on the hardware checksum. |
853 | */ | 848 | */ |
854 | checksummed = | 849 | checksummed = |
855 | likely(efx->rx_checksum_enabled) && | 850 | likely(efx->rx_checksum_enabled) && |
856 | (rx_ev_hdr_type == FSE_AB_RX_EV_HDR_TYPE_IPV4_TCP || | 851 | (rx_ev_hdr_type == FSE_CZ_RX_EV_HDR_TYPE_IPV4V6_TCP || |
857 | rx_ev_hdr_type == FSE_AB_RX_EV_HDR_TYPE_IPV4_UDP); | 852 | rx_ev_hdr_type == FSE_CZ_RX_EV_HDR_TYPE_IPV4V6_UDP); |
858 | } else { | 853 | } else { |
859 | falcon_handle_rx_not_ok(rx_queue, event, &rx_ev_pkt_ok, | 854 | efx_handle_rx_not_ok(rx_queue, event, &rx_ev_pkt_ok, &discard); |
860 | &discard); | ||
861 | checksummed = false; | 855 | checksummed = false; |
862 | } | 856 | } |
863 | 857 | ||
@@ -881,8 +875,8 @@ static void falcon_handle_rx_event(struct efx_channel *channel, | |||
881 | } | 875 | } |
882 | 876 | ||
883 | /* Global events are basically PHY events */ | 877 | /* Global events are basically PHY events */ |
884 | static void falcon_handle_global_event(struct efx_channel *channel, | 878 | static void |
885 | efx_qword_t *event) | 879 | efx_handle_global_event(struct efx_channel *channel, efx_qword_t *event) |
886 | { | 880 | { |
887 | struct efx_nic *efx = channel->efx; | 881 | struct efx_nic *efx = channel->efx; |
888 | bool handled = false; | 882 | bool handled = false; |
@@ -918,8 +912,8 @@ static void falcon_handle_global_event(struct efx_channel *channel, | |||
918 | EFX_QWORD_VAL(*event)); | 912 | EFX_QWORD_VAL(*event)); |
919 | } | 913 | } |
920 | 914 | ||
921 | static void falcon_handle_driver_event(struct efx_channel *channel, | 915 | static void |
922 | efx_qword_t *event) | 916 | efx_handle_driver_event(struct efx_channel *channel, efx_qword_t *event) |
923 | { | 917 | { |
924 | struct efx_nic *efx = channel->efx; | 918 | struct efx_nic *efx = channel->efx; |
925 | unsigned int ev_sub_code; | 919 | unsigned int ev_sub_code; |
@@ -980,7 +974,7 @@ static void falcon_handle_driver_event(struct efx_channel *channel, | |||
980 | } | 974 | } |
981 | } | 975 | } |
982 | 976 | ||
983 | int falcon_process_eventq(struct efx_channel *channel, int rx_quota) | 977 | int efx_nic_process_eventq(struct efx_channel *channel, int rx_quota) |
984 | { | 978 | { |
985 | unsigned int read_ptr; | 979 | unsigned int read_ptr; |
986 | efx_qword_t event, *p_event; | 980 | efx_qword_t event, *p_event; |
@@ -990,10 +984,10 @@ int falcon_process_eventq(struct efx_channel *channel, int rx_quota) | |||
990 | read_ptr = channel->eventq_read_ptr; | 984 | read_ptr = channel->eventq_read_ptr; |
991 | 985 | ||
992 | do { | 986 | do { |
993 | p_event = falcon_event(channel, read_ptr); | 987 | p_event = efx_event(channel, read_ptr); |
994 | event = *p_event; | 988 | event = *p_event; |
995 | 989 | ||
996 | if (!falcon_event_present(&event)) | 990 | if (!efx_event_present(&event)) |
997 | /* End of events */ | 991 | /* End of events */ |
998 | break; | 992 | break; |
999 | 993 | ||
@@ -1007,11 +1001,11 @@ int falcon_process_eventq(struct efx_channel *channel, int rx_quota) | |||
1007 | 1001 | ||
1008 | switch (ev_code) { | 1002 | switch (ev_code) { |
1009 | case FSE_AZ_EV_CODE_RX_EV: | 1003 | case FSE_AZ_EV_CODE_RX_EV: |
1010 | falcon_handle_rx_event(channel, &event); | 1004 | efx_handle_rx_event(channel, &event); |
1011 | ++rx_packets; | 1005 | ++rx_packets; |
1012 | break; | 1006 | break; |
1013 | case FSE_AZ_EV_CODE_TX_EV: | 1007 | case FSE_AZ_EV_CODE_TX_EV: |
1014 | falcon_handle_tx_event(channel, &event); | 1008 | efx_handle_tx_event(channel, &event); |
1015 | break; | 1009 | break; |
1016 | case FSE_AZ_EV_CODE_DRV_GEN_EV: | 1010 | case FSE_AZ_EV_CODE_DRV_GEN_EV: |
1017 | channel->eventq_magic = EFX_QWORD_FIELD( | 1011 | channel->eventq_magic = EFX_QWORD_FIELD( |
@@ -1021,10 +1015,10 @@ int falcon_process_eventq(struct efx_channel *channel, int rx_quota) | |||
1021 | EFX_QWORD_VAL(event)); | 1015 | EFX_QWORD_VAL(event)); |
1022 | break; | 1016 | break; |
1023 | case FSE_AZ_EV_CODE_GLOBAL_EV: | 1017 | case FSE_AZ_EV_CODE_GLOBAL_EV: |
1024 | falcon_handle_global_event(channel, &event); | 1018 | efx_handle_global_event(channel, &event); |
1025 | break; | 1019 | break; |
1026 | case FSE_AZ_EV_CODE_DRIVER_EV: | 1020 | case FSE_AZ_EV_CODE_DRIVER_EV: |
1027 | falcon_handle_driver_event(channel, &event); | 1021 | efx_handle_driver_event(channel, &event); |
1028 | break; | 1022 | break; |
1029 | default: | 1023 | default: |
1030 | EFX_ERR(channel->efx, "channel %d unknown event type %d" | 1024 | EFX_ERR(channel->efx, "channel %d unknown event type %d" |
@@ -1066,16 +1060,16 @@ static void falcon_push_irq_moderation(struct efx_channel *channel) | |||
1066 | } | 1060 | } |
1067 | 1061 | ||
1068 | /* Allocate buffer table entries for event queue */ | 1062 | /* Allocate buffer table entries for event queue */ |
1069 | int falcon_probe_eventq(struct efx_channel *channel) | 1063 | int efx_nic_probe_eventq(struct efx_channel *channel) |
1070 | { | 1064 | { |
1071 | struct efx_nic *efx = channel->efx; | 1065 | struct efx_nic *efx = channel->efx; |
1072 | BUILD_BUG_ON(EFX_EVQ_SIZE < 512 || EFX_EVQ_SIZE > 32768 || | 1066 | BUILD_BUG_ON(EFX_EVQ_SIZE < 512 || EFX_EVQ_SIZE > 32768 || |
1073 | EFX_EVQ_SIZE & EFX_EVQ_MASK); | 1067 | EFX_EVQ_SIZE & EFX_EVQ_MASK); |
1074 | return falcon_alloc_special_buffer(efx, &channel->eventq, | 1068 | return efx_alloc_special_buffer(efx, &channel->eventq, |
1075 | EFX_EVQ_SIZE * sizeof(efx_qword_t)); | 1069 | EFX_EVQ_SIZE * sizeof(efx_qword_t)); |
1076 | } | 1070 | } |
1077 | 1071 | ||
1078 | void falcon_init_eventq(struct efx_channel *channel) | 1072 | void efx_nic_init_eventq(struct efx_channel *channel) |
1079 | { | 1073 | { |
1080 | efx_oword_t evq_ptr; | 1074 | efx_oword_t evq_ptr; |
1081 | struct efx_nic *efx = channel->efx; | 1075 | struct efx_nic *efx = channel->efx; |
@@ -1085,7 +1079,7 @@ void falcon_init_eventq(struct efx_channel *channel) | |||
1085 | channel->eventq.index + channel->eventq.entries - 1); | 1079 | channel->eventq.index + channel->eventq.entries - 1); |
1086 | 1080 | ||
1087 | /* Pin event queue buffer */ | 1081 | /* Pin event queue buffer */ |
1088 | falcon_init_special_buffer(efx, &channel->eventq); | 1082 | efx_init_special_buffer(efx, &channel->eventq); |
1089 | 1083 | ||
1090 | /* Fill event queue with all ones (i.e. empty events) */ | 1084 | /* Fill event queue with all ones (i.e. empty events) */ |
1091 | memset(channel->eventq.addr, 0xff, channel->eventq.len); | 1085 | memset(channel->eventq.addr, 0xff, channel->eventq.len); |
@@ -1098,10 +1092,10 @@ void falcon_init_eventq(struct efx_channel *channel) | |||
1098 | efx_writeo_table(efx, &evq_ptr, efx->type->evq_ptr_tbl_base, | 1092 | efx_writeo_table(efx, &evq_ptr, efx->type->evq_ptr_tbl_base, |
1099 | channel->channel); | 1093 | channel->channel); |
1100 | 1094 | ||
1101 | falcon_push_irq_moderation(channel); | 1095 | efx->type->push_irq_moderation(channel); |
1102 | } | 1096 | } |
1103 | 1097 | ||
1104 | void falcon_fini_eventq(struct efx_channel *channel) | 1098 | void efx_nic_fini_eventq(struct efx_channel *channel) |
1105 | { | 1099 | { |
1106 | efx_oword_t eventq_ptr; | 1100 | efx_oword_t eventq_ptr; |
1107 | struct efx_nic *efx = channel->efx; | 1101 | struct efx_nic *efx = channel->efx; |
@@ -1112,13 +1106,13 @@ void falcon_fini_eventq(struct efx_channel *channel) | |||
1112 | channel->channel); | 1106 | channel->channel); |
1113 | 1107 | ||
1114 | /* Unpin event queue */ | 1108 | /* Unpin event queue */ |
1115 | falcon_fini_special_buffer(efx, &channel->eventq); | 1109 | efx_fini_special_buffer(efx, &channel->eventq); |
1116 | } | 1110 | } |
1117 | 1111 | ||
1118 | /* Free buffers backing event queue */ | 1112 | /* Free buffers backing event queue */ |
1119 | void falcon_remove_eventq(struct efx_channel *channel) | 1113 | void efx_nic_remove_eventq(struct efx_channel *channel) |
1120 | { | 1114 | { |
1121 | falcon_free_special_buffer(channel->efx, &channel->eventq); | 1115 | efx_free_special_buffer(channel->efx, &channel->eventq); |
1122 | } | 1116 | } |
1123 | 1117 | ||
1124 | 1118 | ||
@@ -1126,14 +1120,14 @@ void falcon_remove_eventq(struct efx_channel *channel) | |||
1126 | * process_eventq() should pick up the event and place the value of | 1120 | * process_eventq() should pick up the event and place the value of |
1127 | * "magic" into channel->eventq_magic; | 1121 | * "magic" into channel->eventq_magic; |
1128 | */ | 1122 | */ |
1129 | void falcon_generate_test_event(struct efx_channel *channel, unsigned int magic) | 1123 | void efx_nic_generate_test_event(struct efx_channel *channel, unsigned int magic) |
1130 | { | 1124 | { |
1131 | efx_qword_t test_event; | 1125 | efx_qword_t test_event; |
1132 | 1126 | ||
1133 | EFX_POPULATE_QWORD_2(test_event, FSF_AZ_EV_CODE, | 1127 | EFX_POPULATE_QWORD_2(test_event, FSF_AZ_EV_CODE, |
1134 | FSE_AZ_EV_CODE_DRV_GEN_EV, | 1128 | FSE_AZ_EV_CODE_DRV_GEN_EV, |
1135 | FSF_AZ_DRV_GEN_EV_MAGIC, magic); | 1129 | FSF_AZ_DRV_GEN_EV_MAGIC, magic); |
1136 | falcon_generate_event(channel, &test_event); | 1130 | efx_generate_event(channel, &test_event); |
1137 | } | 1131 | } |
1138 | 1132 | ||
1139 | /************************************************************************** | 1133 | /************************************************************************** |
@@ -1143,7 +1137,7 @@ void falcon_generate_test_event(struct efx_channel *channel, unsigned int magic) | |||
1143 | **************************************************************************/ | 1137 | **************************************************************************/ |
1144 | 1138 | ||
1145 | 1139 | ||
1146 | static void falcon_poll_flush_events(struct efx_nic *efx) | 1140 | static void efx_poll_flush_events(struct efx_nic *efx) |
1147 | { | 1141 | { |
1148 | struct efx_channel *channel = &efx->channel[0]; | 1142 | struct efx_channel *channel = &efx->channel[0]; |
1149 | struct efx_tx_queue *tx_queue; | 1143 | struct efx_tx_queue *tx_queue; |
@@ -1152,11 +1146,11 @@ static void falcon_poll_flush_events(struct efx_nic *efx) | |||
1152 | unsigned int end_ptr = (read_ptr - 1) & EFX_EVQ_MASK; | 1146 | unsigned int end_ptr = (read_ptr - 1) & EFX_EVQ_MASK; |
1153 | 1147 | ||
1154 | do { | 1148 | do { |
1155 | efx_qword_t *event = falcon_event(channel, read_ptr); | 1149 | efx_qword_t *event = efx_event(channel, read_ptr); |
1156 | int ev_code, ev_sub_code, ev_queue; | 1150 | int ev_code, ev_sub_code, ev_queue; |
1157 | bool ev_failed; | 1151 | bool ev_failed; |
1158 | 1152 | ||
1159 | if (!falcon_event_present(event)) | 1153 | if (!efx_event_present(event)) |
1160 | break; | 1154 | break; |
1161 | 1155 | ||
1162 | ev_code = EFX_QWORD_FIELD(*event, FSF_AZ_EV_CODE); | 1156 | ev_code = EFX_QWORD_FIELD(*event, FSF_AZ_EV_CODE); |
@@ -1208,7 +1202,7 @@ static void falcon_prepare_flush(struct efx_nic *efx) | |||
1208 | /* Handle tx and rx flushes at the same time, since they run in | 1202 | /* Handle tx and rx flushes at the same time, since they run in |
1209 | * parallel in the hardware and there's no reason for us to | 1203 | * parallel in the hardware and there's no reason for us to |
1210 | * serialise them */ | 1204 | * serialise them */ |
1211 | int falcon_flush_queues(struct efx_nic *efx) | 1205 | int efx_nic_flush_queues(struct efx_nic *efx) |
1212 | { | 1206 | { |
1213 | struct efx_rx_queue *rx_queue; | 1207 | struct efx_rx_queue *rx_queue; |
1214 | struct efx_tx_queue *tx_queue; | 1208 | struct efx_tx_queue *tx_queue; |
@@ -1219,22 +1213,22 @@ int falcon_flush_queues(struct efx_nic *efx) | |||
1219 | 1213 | ||
1220 | /* Flush all tx queues in parallel */ | 1214 | /* Flush all tx queues in parallel */ |
1221 | efx_for_each_tx_queue(tx_queue, efx) | 1215 | efx_for_each_tx_queue(tx_queue, efx) |
1222 | falcon_flush_tx_queue(tx_queue); | 1216 | efx_flush_tx_queue(tx_queue); |
1223 | 1217 | ||
1224 | /* The hardware supports four concurrent rx flushes, each of which may | 1218 | /* The hardware supports four concurrent rx flushes, each of which may |
1225 | * need to be retried if there is an outstanding descriptor fetch */ | 1219 | * need to be retried if there is an outstanding descriptor fetch */ |
1226 | for (i = 0; i < FALCON_FLUSH_POLL_COUNT; ++i) { | 1220 | for (i = 0; i < EFX_FLUSH_POLL_COUNT; ++i) { |
1227 | rx_pending = tx_pending = 0; | 1221 | rx_pending = tx_pending = 0; |
1228 | efx_for_each_rx_queue(rx_queue, efx) { | 1222 | efx_for_each_rx_queue(rx_queue, efx) { |
1229 | if (rx_queue->flushed == FLUSH_PENDING) | 1223 | if (rx_queue->flushed == FLUSH_PENDING) |
1230 | ++rx_pending; | 1224 | ++rx_pending; |
1231 | } | 1225 | } |
1232 | efx_for_each_rx_queue(rx_queue, efx) { | 1226 | efx_for_each_rx_queue(rx_queue, efx) { |
1233 | if (rx_pending == FALCON_RX_FLUSH_COUNT) | 1227 | if (rx_pending == EFX_RX_FLUSH_COUNT) |
1234 | break; | 1228 | break; |
1235 | if (rx_queue->flushed == FLUSH_FAILED || | 1229 | if (rx_queue->flushed == FLUSH_FAILED || |
1236 | rx_queue->flushed == FLUSH_NONE) { | 1230 | rx_queue->flushed == FLUSH_NONE) { |
1237 | falcon_flush_rx_queue(rx_queue); | 1231 | efx_flush_rx_queue(rx_queue); |
1238 | ++rx_pending; | 1232 | ++rx_pending; |
1239 | } | 1233 | } |
1240 | } | 1234 | } |
@@ -1246,8 +1240,8 @@ int falcon_flush_queues(struct efx_nic *efx) | |||
1246 | if (rx_pending == 0 && tx_pending == 0) | 1240 | if (rx_pending == 0 && tx_pending == 0) |
1247 | return 0; | 1241 | return 0; |
1248 | 1242 | ||
1249 | msleep(FALCON_FLUSH_INTERVAL); | 1243 | msleep(EFX_FLUSH_INTERVAL); |
1250 | falcon_poll_flush_events(efx); | 1244 | efx_poll_flush_events(efx); |
1251 | } | 1245 | } |
1252 | 1246 | ||
1253 | /* Mark the queues as all flushed. We're going to return failure | 1247 | /* Mark the queues as all flushed. We're going to return failure |
@@ -1273,15 +1267,15 @@ int falcon_flush_queues(struct efx_nic *efx) | |||
1273 | 1267 | ||
1274 | /************************************************************************** | 1268 | /************************************************************************** |
1275 | * | 1269 | * |
1276 | * Falcon hardware interrupts | 1270 | * Hardware interrupts |
1277 | * The hardware interrupt handler does very little work; all the event | 1271 | * The hardware interrupt handler does very little work; all the event |
1278 | * queue processing is carried out by per-channel tasklets. | 1272 | * queue processing is carried out by per-channel tasklets. |
1279 | * | 1273 | * |
1280 | **************************************************************************/ | 1274 | **************************************************************************/ |
1281 | 1275 | ||
1282 | /* Enable/disable/generate Falcon interrupts */ | 1276 | /* Enable/disable/generate interrupts */ |
1283 | static inline void falcon_interrupts(struct efx_nic *efx, int enabled, | 1277 | static inline void efx_nic_interrupts(struct efx_nic *efx, |
1284 | int force) | 1278 | bool enabled, bool force) |
1285 | { | 1279 | { |
1286 | efx_oword_t int_en_reg_ker; | 1280 | efx_oword_t int_en_reg_ker; |
1287 | 1281 | ||
@@ -1291,7 +1285,7 @@ static inline void falcon_interrupts(struct efx_nic *efx, int enabled, | |||
1291 | efx_writeo(efx, &int_en_reg_ker, FR_AZ_INT_EN_KER); | 1285 | efx_writeo(efx, &int_en_reg_ker, FR_AZ_INT_EN_KER); |
1292 | } | 1286 | } |
1293 | 1287 | ||
1294 | void falcon_enable_interrupts(struct efx_nic *efx) | 1288 | void efx_nic_enable_interrupts(struct efx_nic *efx) |
1295 | { | 1289 | { |
1296 | struct efx_channel *channel; | 1290 | struct efx_channel *channel; |
1297 | 1291 | ||
@@ -1299,7 +1293,7 @@ void falcon_enable_interrupts(struct efx_nic *efx) | |||
1299 | wmb(); /* Ensure interrupt vector is clear before interrupts enabled */ | 1293 | wmb(); /* Ensure interrupt vector is clear before interrupts enabled */ |
1300 | 1294 | ||
1301 | /* Enable interrupts */ | 1295 | /* Enable interrupts */ |
1302 | falcon_interrupts(efx, 1, 0); | 1296 | efx_nic_interrupts(efx, true, false); |
1303 | 1297 | ||
1304 | /* Force processing of all the channels to get the EVQ RPTRs up to | 1298 | /* Force processing of all the channels to get the EVQ RPTRs up to |
1305 | date */ | 1299 | date */ |
@@ -1307,19 +1301,19 @@ void falcon_enable_interrupts(struct efx_nic *efx) | |||
1307 | efx_schedule_channel(channel); | 1301 | efx_schedule_channel(channel); |
1308 | } | 1302 | } |
1309 | 1303 | ||
1310 | void falcon_disable_interrupts(struct efx_nic *efx) | 1304 | void efx_nic_disable_interrupts(struct efx_nic *efx) |
1311 | { | 1305 | { |
1312 | /* Disable interrupts */ | 1306 | /* Disable interrupts */ |
1313 | falcon_interrupts(efx, 0, 0); | 1307 | efx_nic_interrupts(efx, false, false); |
1314 | } | 1308 | } |
1315 | 1309 | ||
1316 | /* Generate a Falcon test interrupt | 1310 | /* Generate a test interrupt |
1317 | * Interrupt must already have been enabled, otherwise nasty things | 1311 | * Interrupt must already have been enabled, otherwise nasty things |
1318 | * may happen. | 1312 | * may happen. |
1319 | */ | 1313 | */ |
1320 | void falcon_generate_interrupt(struct efx_nic *efx) | 1314 | void efx_nic_generate_interrupt(struct efx_nic *efx) |
1321 | { | 1315 | { |
1322 | falcon_interrupts(efx, 1, 1); | 1316 | efx_nic_interrupts(efx, true, true); |
1323 | } | 1317 | } |
1324 | 1318 | ||
1325 | /* Acknowledge a legacy interrupt from Falcon | 1319 | /* Acknowledge a legacy interrupt from Falcon |
@@ -1332,7 +1326,7 @@ void falcon_generate_interrupt(struct efx_nic *efx) | |||
1332 | * | 1326 | * |
1333 | * NB most hardware supports MSI interrupts | 1327 | * NB most hardware supports MSI interrupts |
1334 | */ | 1328 | */ |
1335 | static inline void falcon_irq_ack_a1(struct efx_nic *efx) | 1329 | inline void falcon_irq_ack_a1(struct efx_nic *efx) |
1336 | { | 1330 | { |
1337 | efx_dword_t reg; | 1331 | efx_dword_t reg; |
1338 | 1332 | ||
@@ -1344,7 +1338,7 @@ static inline void falcon_irq_ack_a1(struct efx_nic *efx) | |||
1344 | /* Process a fatal interrupt | 1338 | /* Process a fatal interrupt |
1345 | * Disable bus mastering ASAP and schedule a reset | 1339 | * Disable bus mastering ASAP and schedule a reset |
1346 | */ | 1340 | */ |
1347 | static irqreturn_t falcon_fatal_interrupt(struct efx_nic *efx) | 1341 | irqreturn_t efx_nic_fatal_interrupt(struct efx_nic *efx) |
1348 | { | 1342 | { |
1349 | struct falcon_nic_data *nic_data = efx->nic_data; | 1343 | struct falcon_nic_data *nic_data = efx->nic_data; |
1350 | efx_oword_t *int_ker = efx->irq_status.addr; | 1344 | efx_oword_t *int_ker = efx->irq_status.addr; |
@@ -1372,18 +1366,18 @@ static irqreturn_t falcon_fatal_interrupt(struct efx_nic *efx) | |||
1372 | 1366 | ||
1373 | /* Disable both devices */ | 1367 | /* Disable both devices */ |
1374 | pci_clear_master(efx->pci_dev); | 1368 | pci_clear_master(efx->pci_dev); |
1375 | if (FALCON_IS_DUAL_FUNC(efx)) | 1369 | if (efx_nic_is_dual_func(efx)) |
1376 | pci_clear_master(nic_data->pci_dev2); | 1370 | pci_clear_master(nic_data->pci_dev2); |
1377 | falcon_disable_interrupts(efx); | 1371 | efx_nic_disable_interrupts(efx); |
1378 | 1372 | ||
1379 | /* Count errors and reset or disable the NIC accordingly */ | 1373 | /* Count errors and reset or disable the NIC accordingly */ |
1380 | if (efx->int_error_count == 0 || | 1374 | if (efx->int_error_count == 0 || |
1381 | time_after(jiffies, efx->int_error_expire)) { | 1375 | time_after(jiffies, efx->int_error_expire)) { |
1382 | efx->int_error_count = 0; | 1376 | efx->int_error_count = 0; |
1383 | efx->int_error_expire = | 1377 | efx->int_error_expire = |
1384 | jiffies + FALCON_INT_ERROR_EXPIRE * HZ; | 1378 | jiffies + EFX_INT_ERROR_EXPIRE * HZ; |
1385 | } | 1379 | } |
1386 | if (++efx->int_error_count < FALCON_MAX_INT_ERRORS) { | 1380 | if (++efx->int_error_count < EFX_MAX_INT_ERRORS) { |
1387 | EFX_ERR(efx, "SYSTEM ERROR - reset scheduled\n"); | 1381 | EFX_ERR(efx, "SYSTEM ERROR - reset scheduled\n"); |
1388 | efx_schedule_reset(efx, RESET_TYPE_INT_ERROR); | 1382 | efx_schedule_reset(efx, RESET_TYPE_INT_ERROR); |
1389 | } else { | 1383 | } else { |
@@ -1395,10 +1389,10 @@ out: | |||
1395 | return IRQ_HANDLED; | 1389 | return IRQ_HANDLED; |
1396 | } | 1390 | } |
1397 | 1391 | ||
1398 | /* Handle a legacy interrupt from Falcon | 1392 | /* Handle a legacy interrupt |
1399 | * Acknowledges the interrupt and schedule event queue processing. | 1393 | * Acknowledges the interrupt and schedule event queue processing. |
1400 | */ | 1394 | */ |
1401 | static irqreturn_t falcon_legacy_interrupt_b0(int irq, void *dev_id) | 1395 | static irqreturn_t efx_legacy_interrupt(int irq, void *dev_id) |
1402 | { | 1396 | { |
1403 | struct efx_nic *efx = dev_id; | 1397 | struct efx_nic *efx = dev_id; |
1404 | efx_oword_t *int_ker = efx->irq_status.addr; | 1398 | efx_oword_t *int_ker = efx->irq_status.addr; |
@@ -1415,13 +1409,13 @@ static irqreturn_t falcon_legacy_interrupt_b0(int irq, void *dev_id) | |||
1415 | /* Check to see if we have a serious error condition */ | 1409 | /* Check to see if we have a serious error condition */ |
1416 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); | 1410 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); |
1417 | if (unlikely(syserr)) | 1411 | if (unlikely(syserr)) |
1418 | return falcon_fatal_interrupt(efx); | 1412 | return efx_nic_fatal_interrupt(efx); |
1419 | 1413 | ||
1420 | /* Schedule processing of any interrupting queues */ | 1414 | /* Schedule processing of any interrupting queues */ |
1421 | efx_for_each_channel(channel, efx) { | 1415 | efx_for_each_channel(channel, efx) { |
1422 | if ((queues & 1) || | 1416 | if ((queues & 1) || |
1423 | falcon_event_present( | 1417 | efx_event_present( |
1424 | falcon_event(channel, channel->eventq_read_ptr))) { | 1418 | efx_event(channel, channel->eventq_read_ptr))) { |
1425 | efx_schedule_channel(channel); | 1419 | efx_schedule_channel(channel); |
1426 | result = IRQ_HANDLED; | 1420 | result = IRQ_HANDLED; |
1427 | } | 1421 | } |
@@ -1438,7 +1432,7 @@ static irqreturn_t falcon_legacy_interrupt_b0(int irq, void *dev_id) | |||
1438 | } | 1432 | } |
1439 | 1433 | ||
1440 | 1434 | ||
1441 | static irqreturn_t falcon_legacy_interrupt_a1(int irq, void *dev_id) | 1435 | irqreturn_t falcon_legacy_interrupt_a1(int irq, void *dev_id) |
1442 | { | 1436 | { |
1443 | struct efx_nic *efx = dev_id; | 1437 | struct efx_nic *efx = dev_id; |
1444 | efx_oword_t *int_ker = efx->irq_status.addr; | 1438 | efx_oword_t *int_ker = efx->irq_status.addr; |
@@ -1461,7 +1455,7 @@ static irqreturn_t falcon_legacy_interrupt_a1(int irq, void *dev_id) | |||
1461 | /* Check to see if we have a serious error condition */ | 1455 | /* Check to see if we have a serious error condition */ |
1462 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); | 1456 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); |
1463 | if (unlikely(syserr)) | 1457 | if (unlikely(syserr)) |
1464 | return falcon_fatal_interrupt(efx); | 1458 | return efx_nic_fatal_interrupt(efx); |
1465 | 1459 | ||
1466 | /* Determine interrupting queues, clear interrupt status | 1460 | /* Determine interrupting queues, clear interrupt status |
1467 | * register and acknowledge the device interrupt. | 1461 | * register and acknowledge the device interrupt. |
@@ -1484,14 +1478,14 @@ static irqreturn_t falcon_legacy_interrupt_a1(int irq, void *dev_id) | |||
1484 | return IRQ_HANDLED; | 1478 | return IRQ_HANDLED; |
1485 | } | 1479 | } |
1486 | 1480 | ||
1487 | /* Handle an MSI interrupt from Falcon | 1481 | /* Handle an MSI interrupt |
1488 | * | 1482 | * |
1489 | * Handle an MSI hardware interrupt. This routine schedules event | 1483 | * Handle an MSI hardware interrupt. This routine schedules event |
1490 | * queue processing. No interrupt acknowledgement cycle is necessary. | 1484 | * queue processing. No interrupt acknowledgement cycle is necessary. |
1491 | * Also, we never need to check that the interrupt is for us, since | 1485 | * Also, we never need to check that the interrupt is for us, since |
1492 | * MSI interrupts cannot be shared. | 1486 | * MSI interrupts cannot be shared. |
1493 | */ | 1487 | */ |
1494 | static irqreturn_t falcon_msi_interrupt(int irq, void *dev_id) | 1488 | static irqreturn_t efx_msi_interrupt(int irq, void *dev_id) |
1495 | { | 1489 | { |
1496 | struct efx_channel *channel = dev_id; | 1490 | struct efx_channel *channel = dev_id; |
1497 | struct efx_nic *efx = channel->efx; | 1491 | struct efx_nic *efx = channel->efx; |
@@ -1505,7 +1499,7 @@ static irqreturn_t falcon_msi_interrupt(int irq, void *dev_id) | |||
1505 | /* Check to see if we have a serious error condition */ | 1499 | /* Check to see if we have a serious error condition */ |
1506 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); | 1500 | syserr = EFX_OWORD_FIELD(*int_ker, FSF_AZ_NET_IVEC_FATAL_INT); |
1507 | if (unlikely(syserr)) | 1501 | if (unlikely(syserr)) |
1508 | return falcon_fatal_interrupt(efx); | 1502 | return efx_nic_fatal_interrupt(efx); |
1509 | 1503 | ||
1510 | /* Schedule processing of the channel */ | 1504 | /* Schedule processing of the channel */ |
1511 | efx_schedule_channel(channel); | 1505 | efx_schedule_channel(channel); |
@@ -1517,7 +1511,7 @@ static irqreturn_t falcon_msi_interrupt(int irq, void *dev_id) | |||
1517 | /* Setup RSS indirection table. | 1511 | /* Setup RSS indirection table. |
1518 | * This maps from the hash value of the packet to RXQ | 1512 | * This maps from the hash value of the packet to RXQ |
1519 | */ | 1513 | */ |
1520 | static void falcon_setup_rss_indir_table(struct efx_nic *efx) | 1514 | static void efx_setup_rss_indir_table(struct efx_nic *efx) |
1521 | { | 1515 | { |
1522 | int i = 0; | 1516 | int i = 0; |
1523 | unsigned long offset; | 1517 | unsigned long offset; |
@@ -1539,7 +1533,7 @@ static void falcon_setup_rss_indir_table(struct efx_nic *efx) | |||
1539 | /* Hook interrupt handler(s) | 1533 | /* Hook interrupt handler(s) |
1540 | * Try MSI and then legacy interrupts. | 1534 | * Try MSI and then legacy interrupts. |
1541 | */ | 1535 | */ |
1542 | int falcon_init_interrupt(struct efx_nic *efx) | 1536 | int efx_nic_init_interrupt(struct efx_nic *efx) |
1543 | { | 1537 | { |
1544 | struct efx_channel *channel; | 1538 | struct efx_channel *channel; |
1545 | int rc; | 1539 | int rc; |
@@ -1547,7 +1541,7 @@ int falcon_init_interrupt(struct efx_nic *efx) | |||
1547 | if (!EFX_INT_MODE_USE_MSI(efx)) { | 1541 | if (!EFX_INT_MODE_USE_MSI(efx)) { |
1548 | irq_handler_t handler; | 1542 | irq_handler_t handler; |
1549 | if (efx_nic_rev(efx) >= EFX_REV_FALCON_B0) | 1543 | if (efx_nic_rev(efx) >= EFX_REV_FALCON_B0) |
1550 | handler = falcon_legacy_interrupt_b0; | 1544 | handler = efx_legacy_interrupt; |
1551 | else | 1545 | else |
1552 | handler = falcon_legacy_interrupt_a1; | 1546 | handler = falcon_legacy_interrupt_a1; |
1553 | 1547 | ||
@@ -1563,7 +1557,7 @@ int falcon_init_interrupt(struct efx_nic *efx) | |||
1563 | 1557 | ||
1564 | /* Hook MSI or MSI-X interrupt */ | 1558 | /* Hook MSI or MSI-X interrupt */ |
1565 | efx_for_each_channel(channel, efx) { | 1559 | efx_for_each_channel(channel, efx) { |
1566 | rc = request_irq(channel->irq, falcon_msi_interrupt, | 1560 | rc = request_irq(channel->irq, efx_msi_interrupt, |
1567 | IRQF_PROBE_SHARED, /* Not shared */ | 1561 | IRQF_PROBE_SHARED, /* Not shared */ |
1568 | channel->name, channel); | 1562 | channel->name, channel); |
1569 | if (rc) { | 1563 | if (rc) { |
@@ -1581,7 +1575,7 @@ int falcon_init_interrupt(struct efx_nic *efx) | |||
1581 | return rc; | 1575 | return rc; |
1582 | } | 1576 | } |
1583 | 1577 | ||
1584 | void falcon_fini_interrupt(struct efx_nic *efx) | 1578 | void efx_nic_fini_interrupt(struct efx_nic *efx) |
1585 | { | 1579 | { |
1586 | struct efx_channel *channel; | 1580 | struct efx_channel *channel; |
1587 | efx_oword_t reg; | 1581 | efx_oword_t reg; |
@@ -2322,8 +2316,8 @@ static int falcon_probe_port(struct efx_nic *efx) | |||
2322 | efx->wanted_fc = EFX_FC_RX; | 2316 | efx->wanted_fc = EFX_FC_RX; |
2323 | 2317 | ||
2324 | /* Allocate buffer for stats */ | 2318 | /* Allocate buffer for stats */ |
2325 | rc = falcon_alloc_buffer(efx, &efx->stats_buffer, | 2319 | rc = efx_nic_alloc_buffer(efx, &efx->stats_buffer, |
2326 | FALCON_MAC_STATS_SIZE); | 2320 | FALCON_MAC_STATS_SIZE); |
2327 | if (rc) | 2321 | if (rc) |
2328 | return rc; | 2322 | return rc; |
2329 | EFX_LOG(efx, "stats buffer at %llx (virt %p phys %llx)\n", | 2323 | EFX_LOG(efx, "stats buffer at %llx (virt %p phys %llx)\n", |
@@ -2336,7 +2330,7 @@ static int falcon_probe_port(struct efx_nic *efx) | |||
2336 | 2330 | ||
2337 | static void falcon_remove_port(struct efx_nic *efx) | 2331 | static void falcon_remove_port(struct efx_nic *efx) |
2338 | { | 2332 | { |
2339 | falcon_free_buffer(efx, &efx->stats_buffer); | 2333 | efx_nic_free_buffer(efx, &efx->stats_buffer); |
2340 | } | 2334 | } |
2341 | 2335 | ||
2342 | /************************************************************************** | 2336 | /************************************************************************** |
@@ -2414,11 +2408,7 @@ static int falcon_test_nvram(struct efx_nic *efx) | |||
2414 | return falcon_read_nvram(efx, NULL); | 2408 | return falcon_read_nvram(efx, NULL); |
2415 | } | 2409 | } |
2416 | 2410 | ||
2417 | /* Registers tested in the falcon register test */ | 2411 | static const struct efx_nic_register_test falcon_b0_register_tests[] = { |
2418 | static struct { | ||
2419 | unsigned address; | ||
2420 | efx_oword_t mask; | ||
2421 | } efx_test_registers[] = { | ||
2422 | { FR_AZ_ADR_REGION, | 2412 | { FR_AZ_ADR_REGION, |
2423 | EFX_OWORD32(0x0001FFFF, 0x0001FFFF, 0x0001FFFF, 0x0001FFFF) }, | 2413 | EFX_OWORD32(0x0001FFFF, 0x0001FFFF, 0x0001FFFF, 0x0001FFFF) }, |
2424 | { FR_AZ_RX_CFG, | 2414 | { FR_AZ_RX_CFG, |
@@ -2464,7 +2454,9 @@ static bool efx_masked_compare_oword(const efx_oword_t *a, const efx_oword_t *b, | |||
2464 | ((a->u64[1] ^ b->u64[1]) & mask->u64[1]); | 2454 | ((a->u64[1] ^ b->u64[1]) & mask->u64[1]); |
2465 | } | 2455 | } |
2466 | 2456 | ||
2467 | static int falcon_b0_test_registers(struct efx_nic *efx) | 2457 | int efx_nic_test_registers(struct efx_nic *efx, |
2458 | const struct efx_nic_register_test *regs, | ||
2459 | size_t n_regs) | ||
2468 | { | 2460 | { |
2469 | unsigned address = 0, i, j; | 2461 | unsigned address = 0, i, j; |
2470 | efx_oword_t mask, imask, original, reg, buf; | 2462 | efx_oword_t mask, imask, original, reg, buf; |
@@ -2472,9 +2464,9 @@ static int falcon_b0_test_registers(struct efx_nic *efx) | |||
2472 | /* Falcon should be in loopback to isolate the XMAC from the PHY */ | 2464 | /* Falcon should be in loopback to isolate the XMAC from the PHY */ |
2473 | WARN_ON(!LOOPBACK_INTERNAL(efx)); | 2465 | WARN_ON(!LOOPBACK_INTERNAL(efx)); |
2474 | 2466 | ||
2475 | for (i = 0; i < ARRAY_SIZE(efx_test_registers); ++i) { | 2467 | for (i = 0; i < n_regs; ++i) { |
2476 | address = efx_test_registers[i].address; | 2468 | address = regs[i].address; |
2477 | mask = imask = efx_test_registers[i].mask; | 2469 | mask = imask = regs[i].mask; |
2478 | EFX_INVERT_OWORD(imask); | 2470 | EFX_INVERT_OWORD(imask); |
2479 | 2471 | ||
2480 | efx_reado(efx, &original, address); | 2472 | efx_reado(efx, &original, address); |
@@ -2517,6 +2509,12 @@ fail: | |||
2517 | return -EIO; | 2509 | return -EIO; |
2518 | } | 2510 | } |
2519 | 2511 | ||
2512 | static int falcon_b0_test_registers(struct efx_nic *efx) | ||
2513 | { | ||
2514 | return efx_nic_test_registers(efx, falcon_b0_register_tests, | ||
2515 | ARRAY_SIZE(falcon_b0_register_tests)); | ||
2516 | } | ||
2517 | |||
2520 | /************************************************************************** | 2518 | /************************************************************************** |
2521 | * | 2519 | * |
2522 | * Device reset | 2520 | * Device reset |
@@ -2542,7 +2540,7 @@ static int falcon_reset_hw(struct efx_nic *efx, enum reset_type method) | |||
2542 | "function prior to hardware reset\n"); | 2540 | "function prior to hardware reset\n"); |
2543 | goto fail1; | 2541 | goto fail1; |
2544 | } | 2542 | } |
2545 | if (FALCON_IS_DUAL_FUNC(efx)) { | 2543 | if (efx_nic_is_dual_func(efx)) { |
2546 | rc = pci_save_state(nic_data->pci_dev2); | 2544 | rc = pci_save_state(nic_data->pci_dev2); |
2547 | if (rc) { | 2545 | if (rc) { |
2548 | EFX_ERR(efx, "failed to backup PCI state of " | 2546 | EFX_ERR(efx, "failed to backup PCI state of " |
@@ -2577,7 +2575,7 @@ static int falcon_reset_hw(struct efx_nic *efx, enum reset_type method) | |||
2577 | 2575 | ||
2578 | /* Restore PCI configuration if needed */ | 2576 | /* Restore PCI configuration if needed */ |
2579 | if (method == RESET_TYPE_WORLD) { | 2577 | if (method == RESET_TYPE_WORLD) { |
2580 | if (FALCON_IS_DUAL_FUNC(efx)) { | 2578 | if (efx_nic_is_dual_func(efx)) { |
2581 | rc = pci_restore_state(nic_data->pci_dev2); | 2579 | rc = pci_restore_state(nic_data->pci_dev2); |
2582 | if (rc) { | 2580 | if (rc) { |
2583 | EFX_ERR(efx, "failed to restore PCI config for " | 2581 | EFX_ERR(efx, "failed to restore PCI config for " |
@@ -2800,16 +2798,22 @@ static int falcon_probe_nvconfig(struct efx_nic *efx) | |||
2800 | return rc; | 2798 | return rc; |
2801 | } | 2799 | } |
2802 | 2800 | ||
2801 | u32 efx_nic_fpga_ver(struct efx_nic *efx) | ||
2802 | { | ||
2803 | efx_oword_t altera_build; | ||
2804 | |||
2805 | efx_reado(efx, &altera_build, FR_AZ_ALTERA_BUILD); | ||
2806 | return EFX_OWORD_FIELD(altera_build, FRF_AZ_ALTERA_BUILD_VER); | ||
2807 | } | ||
2808 | |||
2803 | /* Probe the NIC variant (revision, ASIC vs FPGA, function count, port | 2809 | /* Probe the NIC variant (revision, ASIC vs FPGA, function count, port |
2804 | * count, port speed). Set workaround and feature flags accordingly. | 2810 | * count, port speed). Set workaround and feature flags accordingly. |
2805 | */ | 2811 | */ |
2806 | static int falcon_probe_nic_variant(struct efx_nic *efx) | 2812 | static int falcon_probe_nic_variant(struct efx_nic *efx) |
2807 | { | 2813 | { |
2808 | efx_oword_t altera_build; | ||
2809 | efx_oword_t nic_stat; | 2814 | efx_oword_t nic_stat; |
2810 | 2815 | ||
2811 | efx_reado(efx, &altera_build, FR_AZ_ALTERA_BUILD); | 2816 | if (efx_nic_fpga_ver(efx) != 0) { |
2812 | if (EFX_OWORD_FIELD(altera_build, FRF_AZ_ALTERA_BUILD_VER)) { | ||
2813 | EFX_ERR(efx, "Falcon FPGA not supported\n"); | 2817 | EFX_ERR(efx, "Falcon FPGA not supported\n"); |
2814 | return -ENODEV; | 2818 | return -ENODEV; |
2815 | } | 2819 | } |
@@ -2893,7 +2897,7 @@ static int falcon_probe_nic(struct efx_nic *efx) | |||
2893 | goto fail1; | 2897 | goto fail1; |
2894 | 2898 | ||
2895 | /* Probe secondary function if expected */ | 2899 | /* Probe secondary function if expected */ |
2896 | if (FALCON_IS_DUAL_FUNC(efx)) { | 2900 | if (efx_nic_is_dual_func(efx)) { |
2897 | struct pci_dev *dev = pci_dev_get(efx->pci_dev); | 2901 | struct pci_dev *dev = pci_dev_get(efx->pci_dev); |
2898 | 2902 | ||
2899 | while ((dev = pci_get_device(EFX_VENDID_SFC, FALCON_A_S_DEVID, | 2903 | while ((dev = pci_get_device(EFX_VENDID_SFC, FALCON_A_S_DEVID, |
@@ -2919,7 +2923,7 @@ static int falcon_probe_nic(struct efx_nic *efx) | |||
2919 | } | 2923 | } |
2920 | 2924 | ||
2921 | /* Allocate memory for INT_KER */ | 2925 | /* Allocate memory for INT_KER */ |
2922 | rc = falcon_alloc_buffer(efx, &efx->irq_status, sizeof(efx_oword_t)); | 2926 | rc = efx_nic_alloc_buffer(efx, &efx->irq_status, sizeof(efx_oword_t)); |
2923 | if (rc) | 2927 | if (rc) |
2924 | goto fail4; | 2928 | goto fail4; |
2925 | BUG_ON(efx->irq_status.dma_addr & 0x0f); | 2929 | BUG_ON(efx->irq_status.dma_addr & 0x0f); |
@@ -2965,7 +2969,7 @@ static int falcon_probe_nic(struct efx_nic *efx) | |||
2965 | memset(&board->i2c_adap, 0, sizeof(board->i2c_adap)); | 2969 | memset(&board->i2c_adap, 0, sizeof(board->i2c_adap)); |
2966 | fail5: | 2970 | fail5: |
2967 | falcon_remove_spi_devices(efx); | 2971 | falcon_remove_spi_devices(efx); |
2968 | falcon_free_buffer(efx, &efx->irq_status); | 2972 | efx_nic_free_buffer(efx, &efx->irq_status); |
2969 | fail4: | 2973 | fail4: |
2970 | fail3: | 2974 | fail3: |
2971 | if (nic_data->pci_dev2) { | 2975 | if (nic_data->pci_dev2) { |
@@ -2988,8 +2992,8 @@ static void falcon_init_rx_cfg(struct efx_nic *efx) | |||
2988 | const unsigned ctrl_xon_thr = 20; | 2992 | const unsigned ctrl_xon_thr = 20; |
2989 | const unsigned ctrl_xoff_thr = 25; | 2993 | const unsigned ctrl_xoff_thr = 25; |
2990 | /* RX data FIFO thresholds (256-byte units; size varies) */ | 2994 | /* RX data FIFO thresholds (256-byte units; size varies) */ |
2991 | int data_xon_thr = rx_xon_thresh_bytes >> 8; | 2995 | int data_xon_thr = efx_nic_rx_xon_thresh >> 8; |
2992 | int data_xoff_thr = rx_xoff_thresh_bytes >> 8; | 2996 | int data_xoff_thr = efx_nic_rx_xoff_thresh >> 8; |
2993 | efx_oword_t reg; | 2997 | efx_oword_t reg; |
2994 | 2998 | ||
2995 | efx_reado(efx, ®, FR_AZ_RX_CFG); | 2999 | efx_reado(efx, ®, FR_AZ_RX_CFG); |
@@ -3027,33 +3031,9 @@ static void falcon_init_rx_cfg(struct efx_nic *efx) | |||
3027 | efx_writeo(efx, ®, FR_AZ_RX_CFG); | 3031 | efx_writeo(efx, ®, FR_AZ_RX_CFG); |
3028 | } | 3032 | } |
3029 | 3033 | ||
3030 | /* This call performs hardware-specific global initialisation, such as | 3034 | void efx_nic_init_common(struct efx_nic *efx) |
3031 | * defining the descriptor cache sizes and number of RSS channels. | ||
3032 | * It does not set up any buffers, descriptor rings or event queues. | ||
3033 | */ | ||
3034 | static int falcon_init_nic(struct efx_nic *efx) | ||
3035 | { | 3035 | { |
3036 | efx_oword_t temp; | 3036 | efx_oword_t temp; |
3037 | int rc; | ||
3038 | |||
3039 | /* Use on-chip SRAM */ | ||
3040 | efx_reado(efx, &temp, FR_AB_NIC_STAT); | ||
3041 | EFX_SET_OWORD_FIELD(temp, FRF_AB_ONCHIP_SRAM, 1); | ||
3042 | efx_writeo(efx, &temp, FR_AB_NIC_STAT); | ||
3043 | |||
3044 | /* Set the source of the GMAC clock */ | ||
3045 | if (efx_nic_rev(efx) == EFX_REV_FALCON_B0) { | ||
3046 | efx_reado(efx, &temp, FR_AB_GPIO_CTL); | ||
3047 | EFX_SET_OWORD_FIELD(temp, FRF_AB_USE_NIC_CLK, true); | ||
3048 | efx_writeo(efx, &temp, FR_AB_GPIO_CTL); | ||
3049 | } | ||
3050 | |||
3051 | /* Select the correct MAC */ | ||
3052 | falcon_clock_mac(efx); | ||
3053 | |||
3054 | rc = falcon_reset_sram(efx); | ||
3055 | if (rc) | ||
3056 | return rc; | ||
3057 | 3037 | ||
3058 | /* Set positions of descriptor caches in SRAM. */ | 3038 | /* Set positions of descriptor caches in SRAM. */ |
3059 | EFX_POPULATE_OWORD_1(temp, FRF_AZ_SRM_TX_DC_BASE_ADR, | 3039 | EFX_POPULATE_OWORD_1(temp, FRF_AZ_SRM_TX_DC_BASE_ADR, |
@@ -3084,15 +3064,6 @@ static int falcon_init_nic(struct efx_nic *efx) | |||
3084 | FRF_AZ_INT_ADR_KER, efx->irq_status.dma_addr); | 3064 | FRF_AZ_INT_ADR_KER, efx->irq_status.dma_addr); |
3085 | efx_writeo(efx, &temp, FR_AZ_INT_ADR_KER); | 3065 | efx_writeo(efx, &temp, FR_AZ_INT_ADR_KER); |
3086 | 3066 | ||
3087 | /* Clear the parity enables on the TX data fifos as | ||
3088 | * they produce false parity errors because of timing issues | ||
3089 | */ | ||
3090 | if (EFX_WORKAROUND_5129(efx)) { | ||
3091 | efx_reado(efx, &temp, FR_AZ_CSR_SPARE); | ||
3092 | EFX_SET_OWORD_FIELD(temp, FRF_AB_MEM_PERR_EN_TX_DATA, 0); | ||
3093 | efx_writeo(efx, &temp, FR_AZ_CSR_SPARE); | ||
3094 | } | ||
3095 | |||
3096 | /* Enable all the genuinely fatal interrupts. (They are still | 3067 | /* Enable all the genuinely fatal interrupts. (They are still |
3097 | * masked by the overall interrupt mask, controlled by | 3068 | * masked by the overall interrupt mask, controlled by |
3098 | * falcon_interrupts()). | 3069 | * falcon_interrupts()). |
@@ -3106,6 +3077,64 @@ static int falcon_init_nic(struct efx_nic *efx) | |||
3106 | EFX_INVERT_OWORD(temp); | 3077 | EFX_INVERT_OWORD(temp); |
3107 | efx_writeo(efx, &temp, FR_AZ_FATAL_INTR_KER); | 3078 | efx_writeo(efx, &temp, FR_AZ_FATAL_INTR_KER); |
3108 | 3079 | ||
3080 | efx_setup_rss_indir_table(efx); | ||
3081 | |||
3082 | /* Disable the ugly timer-based TX DMA backoff and allow TX DMA to be | ||
3083 | * controlled by the RX FIFO fill level. Set arbitration to one pkt/Q. | ||
3084 | */ | ||
3085 | efx_reado(efx, &temp, FR_AZ_TX_RESERVED); | ||
3086 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_RX_SPACER, 0xfe); | ||
3087 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_RX_SPACER_EN, 1); | ||
3088 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_ONE_PKT_PER_Q, 1); | ||
3089 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_PUSH_EN, 0); | ||
3090 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_DIS_NON_IP_EV, 1); | ||
3091 | /* Enable SW_EV to inherit in char driver - assume harmless here */ | ||
3092 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_SOFT_EVT_EN, 1); | ||
3093 | /* Prefetch threshold 2 => fetch when descriptor cache half empty */ | ||
3094 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_PREF_THRESHOLD, 2); | ||
3095 | /* Squash TX of packets of 16 bytes or less */ | ||
3096 | if (efx_nic_rev(efx) >= EFX_REV_FALCON_B0) | ||
3097 | EFX_SET_OWORD_FIELD(temp, FRF_BZ_TX_FLUSH_MIN_LEN_EN, 1); | ||
3098 | efx_writeo(efx, &temp, FR_AZ_TX_RESERVED); | ||
3099 | } | ||
3100 | |||
3101 | /* This call performs hardware-specific global initialisation, such as | ||
3102 | * defining the descriptor cache sizes and number of RSS channels. | ||
3103 | * It does not set up any buffers, descriptor rings or event queues. | ||
3104 | */ | ||
3105 | static int falcon_init_nic(struct efx_nic *efx) | ||
3106 | { | ||
3107 | efx_oword_t temp; | ||
3108 | int rc; | ||
3109 | |||
3110 | /* Use on-chip SRAM */ | ||
3111 | efx_reado(efx, &temp, FR_AB_NIC_STAT); | ||
3112 | EFX_SET_OWORD_FIELD(temp, FRF_AB_ONCHIP_SRAM, 1); | ||
3113 | efx_writeo(efx, &temp, FR_AB_NIC_STAT); | ||
3114 | |||
3115 | /* Set the source of the GMAC clock */ | ||
3116 | if (efx_nic_rev(efx) == EFX_REV_FALCON_B0) { | ||
3117 | efx_reado(efx, &temp, FR_AB_GPIO_CTL); | ||
3118 | EFX_SET_OWORD_FIELD(temp, FRF_AB_USE_NIC_CLK, true); | ||
3119 | efx_writeo(efx, &temp, FR_AB_GPIO_CTL); | ||
3120 | } | ||
3121 | |||
3122 | /* Select the correct MAC */ | ||
3123 | falcon_clock_mac(efx); | ||
3124 | |||
3125 | rc = falcon_reset_sram(efx); | ||
3126 | if (rc) | ||
3127 | return rc; | ||
3128 | |||
3129 | /* Clear the parity enables on the TX data fifos as | ||
3130 | * they produce false parity errors because of timing issues | ||
3131 | */ | ||
3132 | if (EFX_WORKAROUND_5129(efx)) { | ||
3133 | efx_reado(efx, &temp, FR_AZ_CSR_SPARE); | ||
3134 | EFX_SET_OWORD_FIELD(temp, FRF_AB_MEM_PERR_EN_TX_DATA, 0); | ||
3135 | efx_writeo(efx, &temp, FR_AZ_CSR_SPARE); | ||
3136 | } | ||
3137 | |||
3109 | if (EFX_WORKAROUND_7244(efx)) { | 3138 | if (EFX_WORKAROUND_7244(efx)) { |
3110 | efx_reado(efx, &temp, FR_BZ_RX_FILTER_CTL); | 3139 | efx_reado(efx, &temp, FR_BZ_RX_FILTER_CTL); |
3111 | EFX_SET_OWORD_FIELD(temp, FRF_BZ_UDP_FULL_SRCH_LIMIT, 8); | 3140 | EFX_SET_OWORD_FIELD(temp, FRF_BZ_UDP_FULL_SRCH_LIMIT, 8); |
@@ -3115,8 +3144,6 @@ static int falcon_init_nic(struct efx_nic *efx) | |||
3115 | efx_writeo(efx, &temp, FR_BZ_RX_FILTER_CTL); | 3144 | efx_writeo(efx, &temp, FR_BZ_RX_FILTER_CTL); |
3116 | } | 3145 | } |
3117 | 3146 | ||
3118 | falcon_setup_rss_indir_table(efx); | ||
3119 | |||
3120 | /* XXX This is documented only for Falcon A0/A1 */ | 3147 | /* XXX This is documented only for Falcon A0/A1 */ |
3121 | /* Setup RX. Wait for descriptor is broken and must | 3148 | /* Setup RX. Wait for descriptor is broken and must |
3122 | * be disabled. RXDP recovery shouldn't be needed, but is. | 3149 | * be disabled. RXDP recovery shouldn't be needed, but is. |
@@ -3128,24 +3155,6 @@ static int falcon_init_nic(struct efx_nic *efx) | |||
3128 | EFX_SET_OWORD_FIELD(temp, FRF_AA_RX_ISCSI_DIS, 1); | 3155 | EFX_SET_OWORD_FIELD(temp, FRF_AA_RX_ISCSI_DIS, 1); |
3129 | efx_writeo(efx, &temp, FR_AA_RX_SELF_RST); | 3156 | efx_writeo(efx, &temp, FR_AA_RX_SELF_RST); |
3130 | 3157 | ||
3131 | /* Disable the ugly timer-based TX DMA backoff and allow TX DMA to be | ||
3132 | * controlled by the RX FIFO fill level. Set arbitration to one pkt/Q. | ||
3133 | */ | ||
3134 | efx_reado(efx, &temp, FR_AZ_TX_RESERVED); | ||
3135 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_RX_SPACER, 0xfe); | ||
3136 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_RX_SPACER_EN, 1); | ||
3137 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_ONE_PKT_PER_Q, 1); | ||
3138 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_PUSH_EN, 0); | ||
3139 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_DIS_NON_IP_EV, 1); | ||
3140 | /* Enable SW_EV to inherit in char driver - assume harmless here */ | ||
3141 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_SOFT_EVT_EN, 1); | ||
3142 | /* Prefetch threshold 2 => fetch when descriptor cache half empty */ | ||
3143 | EFX_SET_OWORD_FIELD(temp, FRF_AZ_TX_PREF_THRESHOLD, 2); | ||
3144 | /* Squash TX of packets of 16 bytes or less */ | ||
3145 | if (efx_nic_rev(efx) >= EFX_REV_FALCON_B0) | ||
3146 | EFX_SET_OWORD_FIELD(temp, FRF_BZ_TX_FLUSH_MIN_LEN_EN, 1); | ||
3147 | efx_writeo(efx, &temp, FR_AZ_TX_RESERVED); | ||
3148 | |||
3149 | /* Do not enable TX_NO_EOP_DISC_EN, since it limits packets to 16 | 3158 | /* Do not enable TX_NO_EOP_DISC_EN, since it limits packets to 16 |
3150 | * descriptors (which is bad). | 3159 | * descriptors (which is bad). |
3151 | */ | 3160 | */ |
@@ -3161,6 +3170,8 @@ static int falcon_init_nic(struct efx_nic *efx) | |||
3161 | efx_writeo(efx, &temp, FR_BZ_DP_CTRL); | 3170 | efx_writeo(efx, &temp, FR_BZ_DP_CTRL); |
3162 | } | 3171 | } |
3163 | 3172 | ||
3173 | efx_nic_init_common(efx); | ||
3174 | |||
3164 | return 0; | 3175 | return 0; |
3165 | } | 3176 | } |
3166 | 3177 | ||
@@ -3178,7 +3189,7 @@ static void falcon_remove_nic(struct efx_nic *efx) | |||
3178 | memset(&board->i2c_adap, 0, sizeof(board->i2c_adap)); | 3189 | memset(&board->i2c_adap, 0, sizeof(board->i2c_adap)); |
3179 | 3190 | ||
3180 | falcon_remove_spi_devices(efx); | 3191 | falcon_remove_spi_devices(efx); |
3181 | falcon_free_buffer(efx, &efx->irq_status); | 3192 | efx_nic_free_buffer(efx, &efx->irq_status); |
3182 | 3193 | ||
3183 | falcon_reset_hw(efx, RESET_TYPE_ALL); | 3194 | falcon_reset_hw(efx, RESET_TYPE_ALL); |
3184 | 3195 | ||