diff options
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/sfc/efx.c | 76 | ||||
-rw-r--r-- | drivers/net/sfc/efx.h | 2 | ||||
-rw-r--r-- | drivers/net/sfc/ethtool.c | 8 | ||||
-rw-r--r-- | drivers/net/sfc/falcon.c | 30 | ||||
-rw-r--r-- | drivers/net/sfc/falcon.h | 6 | ||||
-rw-r--r-- | drivers/net/sfc/rx.c | 4 | ||||
-rw-r--r-- | drivers/net/sfc/rx.h | 2 | ||||
-rw-r--r-- | drivers/net/sfc/tx.c | 4 | ||||
-rw-r--r-- | drivers/net/sfc/tx.h | 2 |
9 files changed, 39 insertions, 95 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c index c41035a99381..f226dcf18c7d 100644 --- a/drivers/net/sfc/efx.c +++ b/drivers/net/sfc/efx.c | |||
@@ -282,13 +282,13 @@ static int efx_probe_eventq(struct efx_channel *channel) | |||
282 | } | 282 | } |
283 | 283 | ||
284 | /* Prepare channel's event queue */ | 284 | /* Prepare channel's event queue */ |
285 | static int efx_init_eventq(struct efx_channel *channel) | 285 | static void efx_init_eventq(struct efx_channel *channel) |
286 | { | 286 | { |
287 | EFX_LOG(channel->efx, "chan %d init event queue\n", channel->channel); | 287 | EFX_LOG(channel->efx, "chan %d init event queue\n", channel->channel); |
288 | 288 | ||
289 | channel->eventq_read_ptr = 0; | 289 | channel->eventq_read_ptr = 0; |
290 | 290 | ||
291 | return falcon_init_eventq(channel); | 291 | falcon_init_eventq(channel); |
292 | } | 292 | } |
293 | 293 | ||
294 | static void efx_fini_eventq(struct efx_channel *channel) | 294 | static void efx_fini_eventq(struct efx_channel *channel) |
@@ -354,12 +354,11 @@ static int efx_probe_channel(struct efx_channel *channel) | |||
354 | * to propagate configuration changes (mtu, checksum offload), or | 354 | * to propagate configuration changes (mtu, checksum offload), or |
355 | * to clear hardware error conditions | 355 | * to clear hardware error conditions |
356 | */ | 356 | */ |
357 | static int efx_init_channels(struct efx_nic *efx) | 357 | static void efx_init_channels(struct efx_nic *efx) |
358 | { | 358 | { |
359 | struct efx_tx_queue *tx_queue; | 359 | struct efx_tx_queue *tx_queue; |
360 | struct efx_rx_queue *rx_queue; | 360 | struct efx_rx_queue *rx_queue; |
361 | struct efx_channel *channel; | 361 | struct efx_channel *channel; |
362 | int rc = 0; | ||
363 | 362 | ||
364 | /* Calculate the rx buffer allocation parameters required to | 363 | /* Calculate the rx buffer allocation parameters required to |
365 | * support the current MTU, including padding for header | 364 | * support the current MTU, including padding for header |
@@ -374,36 +373,20 @@ static int efx_init_channels(struct efx_nic *efx) | |||
374 | efx_for_each_channel(channel, efx) { | 373 | efx_for_each_channel(channel, efx) { |
375 | EFX_LOG(channel->efx, "init chan %d\n", channel->channel); | 374 | EFX_LOG(channel->efx, "init chan %d\n", channel->channel); |
376 | 375 | ||
377 | rc = efx_init_eventq(channel); | 376 | efx_init_eventq(channel); |
378 | if (rc) | ||
379 | goto err; | ||
380 | 377 | ||
381 | efx_for_each_channel_tx_queue(tx_queue, channel) { | 378 | efx_for_each_channel_tx_queue(tx_queue, channel) |
382 | rc = efx_init_tx_queue(tx_queue); | 379 | efx_init_tx_queue(tx_queue); |
383 | if (rc) | ||
384 | goto err; | ||
385 | } | ||
386 | 380 | ||
387 | /* The rx buffer allocation strategy is MTU dependent */ | 381 | /* The rx buffer allocation strategy is MTU dependent */ |
388 | efx_rx_strategy(channel); | 382 | efx_rx_strategy(channel); |
389 | 383 | ||
390 | efx_for_each_channel_rx_queue(rx_queue, channel) { | 384 | efx_for_each_channel_rx_queue(rx_queue, channel) |
391 | rc = efx_init_rx_queue(rx_queue); | 385 | efx_init_rx_queue(rx_queue); |
392 | if (rc) | ||
393 | goto err; | ||
394 | } | ||
395 | 386 | ||
396 | WARN_ON(channel->rx_pkt != NULL); | 387 | WARN_ON(channel->rx_pkt != NULL); |
397 | efx_rx_strategy(channel); | 388 | efx_rx_strategy(channel); |
398 | } | 389 | } |
399 | |||
400 | return 0; | ||
401 | |||
402 | err: | ||
403 | EFX_ERR(efx, "failed to initialise channel %d\n", | ||
404 | channel ? channel->channel : -1); | ||
405 | efx_fini_channels(efx); | ||
406 | return rc; | ||
407 | } | 390 | } |
408 | 391 | ||
409 | /* This enables event queue processing and packet transmission. | 392 | /* This enables event queue processing and packet transmission. |
@@ -1121,24 +1104,16 @@ static void efx_remove_all(struct efx_nic *efx) | |||
1121 | } | 1104 | } |
1122 | 1105 | ||
1123 | /* A convinience function to safely flush all the queues */ | 1106 | /* A convinience function to safely flush all the queues */ |
1124 | int efx_flush_queues(struct efx_nic *efx) | 1107 | void efx_flush_queues(struct efx_nic *efx) |
1125 | { | 1108 | { |
1126 | int rc; | ||
1127 | |||
1128 | EFX_ASSERT_RESET_SERIALISED(efx); | 1109 | EFX_ASSERT_RESET_SERIALISED(efx); |
1129 | 1110 | ||
1130 | efx_stop_all(efx); | 1111 | efx_stop_all(efx); |
1131 | 1112 | ||
1132 | efx_fini_channels(efx); | 1113 | efx_fini_channels(efx); |
1133 | rc = efx_init_channels(efx); | 1114 | efx_init_channels(efx); |
1134 | if (rc) { | ||
1135 | efx_schedule_reset(efx, RESET_TYPE_DISABLE); | ||
1136 | return rc; | ||
1137 | } | ||
1138 | 1115 | ||
1139 | efx_start_all(efx); | 1116 | efx_start_all(efx); |
1140 | |||
1141 | return 0; | ||
1142 | } | 1117 | } |
1143 | 1118 | ||
1144 | /************************************************************************** | 1119 | /************************************************************************** |
@@ -1311,7 +1286,6 @@ static int efx_net_open(struct net_device *net_dev) | |||
1311 | static int efx_net_stop(struct net_device *net_dev) | 1286 | static int efx_net_stop(struct net_device *net_dev) |
1312 | { | 1287 | { |
1313 | struct efx_nic *efx = netdev_priv(net_dev); | 1288 | struct efx_nic *efx = netdev_priv(net_dev); |
1314 | int rc; | ||
1315 | 1289 | ||
1316 | EFX_LOG(efx, "closing %s on CPU %d\n", net_dev->name, | 1290 | EFX_LOG(efx, "closing %s on CPU %d\n", net_dev->name, |
1317 | raw_smp_processor_id()); | 1291 | raw_smp_processor_id()); |
@@ -1319,9 +1293,7 @@ static int efx_net_stop(struct net_device *net_dev) | |||
1319 | /* Stop the device and flush all the channels */ | 1293 | /* Stop the device and flush all the channels */ |
1320 | efx_stop_all(efx); | 1294 | efx_stop_all(efx); |
1321 | efx_fini_channels(efx); | 1295 | efx_fini_channels(efx); |
1322 | rc = efx_init_channels(efx); | 1296 | efx_init_channels(efx); |
1323 | if (rc) | ||
1324 | efx_schedule_reset(efx, RESET_TYPE_DISABLE); | ||
1325 | 1297 | ||
1326 | return 0; | 1298 | return 0; |
1327 | } | 1299 | } |
@@ -1404,16 +1376,10 @@ static int efx_change_mtu(struct net_device *net_dev, int new_mtu) | |||
1404 | 1376 | ||
1405 | efx_fini_channels(efx); | 1377 | efx_fini_channels(efx); |
1406 | net_dev->mtu = new_mtu; | 1378 | net_dev->mtu = new_mtu; |
1407 | rc = efx_init_channels(efx); | 1379 | efx_init_channels(efx); |
1408 | if (rc) | ||
1409 | goto fail; | ||
1410 | 1380 | ||
1411 | efx_start_all(efx); | 1381 | efx_start_all(efx); |
1412 | return rc; | 1382 | return rc; |
1413 | |||
1414 | fail: | ||
1415 | efx_schedule_reset(efx, RESET_TYPE_DISABLE); | ||
1416 | return rc; | ||
1417 | } | 1383 | } |
1418 | 1384 | ||
1419 | static int efx_set_mac_address(struct net_device *net_dev, void *data) | 1385 | static int efx_set_mac_address(struct net_device *net_dev, void *data) |
@@ -1588,22 +1554,19 @@ static int efx_reset_up(struct efx_nic *efx, struct ethtool_cmd *ecmd) | |||
1588 | { | 1554 | { |
1589 | int rc; | 1555 | int rc; |
1590 | 1556 | ||
1591 | rc = efx_init_channels(efx); | 1557 | efx_init_channels(efx); |
1592 | if (rc) | ||
1593 | goto fail1; | ||
1594 | 1558 | ||
1595 | /* Restore MAC and PHY settings. */ | 1559 | /* Restore MAC and PHY settings. */ |
1596 | rc = falcon_xmac_set_settings(efx, ecmd); | 1560 | rc = falcon_xmac_set_settings(efx, ecmd); |
1597 | if (rc) { | 1561 | if (rc) { |
1598 | EFX_ERR(efx, "could not restore PHY settings\n"); | 1562 | EFX_ERR(efx, "could not restore PHY settings\n"); |
1599 | goto fail2; | 1563 | goto fail; |
1600 | } | 1564 | } |
1601 | 1565 | ||
1602 | return 0; | 1566 | return 0; |
1603 | 1567 | ||
1604 | fail2: | 1568 | fail: |
1605 | efx_fini_channels(efx); | 1569 | efx_fini_channels(efx); |
1606 | fail1: | ||
1607 | return rc; | 1570 | return rc; |
1608 | } | 1571 | } |
1609 | 1572 | ||
@@ -2023,19 +1986,16 @@ static int efx_pci_probe_main(struct efx_nic *efx) | |||
2023 | goto fail5; | 1986 | goto fail5; |
2024 | } | 1987 | } |
2025 | 1988 | ||
2026 | rc = efx_init_channels(efx); | 1989 | efx_init_channels(efx); |
2027 | if (rc) | ||
2028 | goto fail6; | ||
2029 | 1990 | ||
2030 | rc = falcon_init_interrupt(efx); | 1991 | rc = falcon_init_interrupt(efx); |
2031 | if (rc) | 1992 | if (rc) |
2032 | goto fail7; | 1993 | goto fail6; |
2033 | 1994 | ||
2034 | return 0; | 1995 | return 0; |
2035 | 1996 | ||
2036 | fail7: | ||
2037 | efx_fini_channels(efx); | ||
2038 | fail6: | 1997 | fail6: |
1998 | efx_fini_channels(efx); | ||
2039 | efx_fini_port(efx); | 1999 | efx_fini_port(efx); |
2040 | fail5: | 2000 | fail5: |
2041 | fail4: | 2001 | fail4: |
diff --git a/drivers/net/sfc/efx.h b/drivers/net/sfc/efx.h index 29a1c5830587..9a8c283fa883 100644 --- a/drivers/net/sfc/efx.h +++ b/drivers/net/sfc/efx.h | |||
@@ -33,7 +33,7 @@ extern void efx_schedule_slow_fill(struct efx_rx_queue *rx_queue, int delay); | |||
33 | 33 | ||
34 | /* Channels */ | 34 | /* Channels */ |
35 | extern void efx_process_channel_now(struct efx_channel *channel); | 35 | extern void efx_process_channel_now(struct efx_channel *channel); |
36 | extern int efx_flush_queues(struct efx_nic *efx); | 36 | extern void efx_flush_queues(struct efx_nic *efx); |
37 | 37 | ||
38 | /* Ports */ | 38 | /* Ports */ |
39 | extern void efx_reconfigure_port(struct efx_nic *efx); | 39 | extern void efx_reconfigure_port(struct efx_nic *efx); |
diff --git a/drivers/net/sfc/ethtool.c b/drivers/net/sfc/ethtool.c index 906d18a65260..79894160a9a4 100644 --- a/drivers/net/sfc/ethtool.c +++ b/drivers/net/sfc/ethtool.c | |||
@@ -503,10 +503,10 @@ static void efx_ethtool_self_test(struct net_device *net_dev, | |||
503 | if (offline) { | 503 | if (offline) { |
504 | /* Stop the kernel from sending packets during the test. */ | 504 | /* Stop the kernel from sending packets during the test. */ |
505 | efx_stop_queue(efx); | 505 | efx_stop_queue(efx); |
506 | rc = efx_flush_queues(efx); | 506 | efx_flush_queues(efx); |
507 | if (!rc) | 507 | |
508 | rc = efx_offline_test(efx, &efx_tests, | 508 | rc = efx_offline_test(efx, &efx_tests, |
509 | efx->loopback_modes); | 509 | efx->loopback_modes); |
510 | efx_wake_queue(efx); | 510 | efx_wake_queue(efx); |
511 | } | 511 | } |
512 | 512 | ||
diff --git a/drivers/net/sfc/falcon.c b/drivers/net/sfc/falcon.c index 96cb5d031ed7..e66d6cf03adc 100644 --- a/drivers/net/sfc/falcon.c +++ b/drivers/net/sfc/falcon.c | |||
@@ -242,7 +242,7 @@ static struct i2c_algo_bit_data falcon_i2c_bit_operations = { | |||
242 | * falcon_alloc_special_buffer()) in Falcon's buffer table, allowing | 242 | * falcon_alloc_special_buffer()) in Falcon's buffer table, allowing |
243 | * it to be used for event queues, descriptor rings etc. | 243 | * it to be used for event queues, descriptor rings etc. |
244 | */ | 244 | */ |
245 | static int | 245 | static void |
246 | falcon_init_special_buffer(struct efx_nic *efx, | 246 | falcon_init_special_buffer(struct efx_nic *efx, |
247 | struct efx_special_buffer *buffer) | 247 | struct efx_special_buffer *buffer) |
248 | { | 248 | { |
@@ -266,8 +266,6 @@ falcon_init_special_buffer(struct efx_nic *efx, | |||
266 | BUF_OWNER_ID_FBUF, 0); | 266 | BUF_OWNER_ID_FBUF, 0); |
267 | falcon_write_sram(efx, &buf_desc, index); | 267 | falcon_write_sram(efx, &buf_desc, index); |
268 | } | 268 | } |
269 | |||
270 | return 0; | ||
271 | } | 269 | } |
272 | 270 | ||
273 | /* Unmaps a buffer from Falcon and clears the buffer table entries */ | 271 | /* Unmaps a buffer from Falcon and clears the buffer table entries */ |
@@ -449,16 +447,13 @@ int falcon_probe_tx(struct efx_tx_queue *tx_queue) | |||
449 | sizeof(efx_qword_t)); | 447 | sizeof(efx_qword_t)); |
450 | } | 448 | } |
451 | 449 | ||
452 | int falcon_init_tx(struct efx_tx_queue *tx_queue) | 450 | void falcon_init_tx(struct efx_tx_queue *tx_queue) |
453 | { | 451 | { |
454 | efx_oword_t tx_desc_ptr; | 452 | efx_oword_t tx_desc_ptr; |
455 | struct efx_nic *efx = tx_queue->efx; | 453 | struct efx_nic *efx = tx_queue->efx; |
456 | int rc; | ||
457 | 454 | ||
458 | /* Pin TX descriptor ring */ | 455 | /* Pin TX descriptor ring */ |
459 | rc = falcon_init_special_buffer(efx, &tx_queue->txd); | 456 | falcon_init_special_buffer(efx, &tx_queue->txd); |
460 | if (rc) | ||
461 | return rc; | ||
462 | 457 | ||
463 | /* Push TX descriptor ring to card */ | 458 | /* Push TX descriptor ring to card */ |
464 | EFX_POPULATE_OWORD_10(tx_desc_ptr, | 459 | EFX_POPULATE_OWORD_10(tx_desc_ptr, |
@@ -495,8 +490,6 @@ int falcon_init_tx(struct efx_tx_queue *tx_queue) | |||
495 | set_bit_le(tx_queue->queue, (void *)®); | 490 | set_bit_le(tx_queue->queue, (void *)®); |
496 | falcon_write(efx, ®, TX_CHKSM_CFG_REG_KER_A1); | 491 | falcon_write(efx, ®, TX_CHKSM_CFG_REG_KER_A1); |
497 | } | 492 | } |
498 | |||
499 | return 0; | ||
500 | } | 493 | } |
501 | 494 | ||
502 | static int falcon_flush_tx_queue(struct efx_tx_queue *tx_queue) | 495 | static int falcon_flush_tx_queue(struct efx_tx_queue *tx_queue) |
@@ -639,11 +632,10 @@ int falcon_probe_rx(struct efx_rx_queue *rx_queue) | |||
639 | sizeof(efx_qword_t)); | 632 | sizeof(efx_qword_t)); |
640 | } | 633 | } |
641 | 634 | ||
642 | int falcon_init_rx(struct efx_rx_queue *rx_queue) | 635 | void falcon_init_rx(struct efx_rx_queue *rx_queue) |
643 | { | 636 | { |
644 | efx_oword_t rx_desc_ptr; | 637 | efx_oword_t rx_desc_ptr; |
645 | struct efx_nic *efx = rx_queue->efx; | 638 | struct efx_nic *efx = rx_queue->efx; |
646 | int rc; | ||
647 | bool is_b0 = falcon_rev(efx) >= FALCON_REV_B0; | 639 | bool is_b0 = falcon_rev(efx) >= FALCON_REV_B0; |
648 | bool iscsi_digest_en = is_b0; | 640 | bool iscsi_digest_en = is_b0; |
649 | 641 | ||
@@ -652,9 +644,7 @@ int falcon_init_rx(struct efx_rx_queue *rx_queue) | |||
652 | rx_queue->rxd.index + rx_queue->rxd.entries - 1); | 644 | rx_queue->rxd.index + rx_queue->rxd.entries - 1); |
653 | 645 | ||
654 | /* Pin RX descriptor ring */ | 646 | /* Pin RX descriptor ring */ |
655 | rc = falcon_init_special_buffer(efx, &rx_queue->rxd); | 647 | falcon_init_special_buffer(efx, &rx_queue->rxd); |
656 | if (rc) | ||
657 | return rc; | ||
658 | 648 | ||
659 | /* Push RX descriptor ring to card */ | 649 | /* Push RX descriptor ring to card */ |
660 | EFX_POPULATE_OWORD_10(rx_desc_ptr, | 650 | EFX_POPULATE_OWORD_10(rx_desc_ptr, |
@@ -671,7 +661,6 @@ int falcon_init_rx(struct efx_rx_queue *rx_queue) | |||
671 | RX_DESCQ_EN, 1); | 661 | RX_DESCQ_EN, 1); |
672 | falcon_write_table(efx, &rx_desc_ptr, efx->type->rxd_ptr_tbl_base, | 662 | falcon_write_table(efx, &rx_desc_ptr, efx->type->rxd_ptr_tbl_base, |
673 | rx_queue->queue); | 663 | rx_queue->queue); |
674 | return 0; | ||
675 | } | 664 | } |
676 | 665 | ||
677 | static int falcon_flush_rx_queue(struct efx_rx_queue *rx_queue) | 666 | static int falcon_flush_rx_queue(struct efx_rx_queue *rx_queue) |
@@ -1205,20 +1194,17 @@ int falcon_probe_eventq(struct efx_channel *channel) | |||
1205 | return falcon_alloc_special_buffer(efx, &channel->eventq, evq_size); | 1194 | return falcon_alloc_special_buffer(efx, &channel->eventq, evq_size); |
1206 | } | 1195 | } |
1207 | 1196 | ||
1208 | int falcon_init_eventq(struct efx_channel *channel) | 1197 | void falcon_init_eventq(struct efx_channel *channel) |
1209 | { | 1198 | { |
1210 | efx_oword_t evq_ptr; | 1199 | efx_oword_t evq_ptr; |
1211 | struct efx_nic *efx = channel->efx; | 1200 | struct efx_nic *efx = channel->efx; |
1212 | int rc; | ||
1213 | 1201 | ||
1214 | EFX_LOG(efx, "channel %d event queue in special buffers %d-%d\n", | 1202 | EFX_LOG(efx, "channel %d event queue in special buffers %d-%d\n", |
1215 | channel->channel, channel->eventq.index, | 1203 | channel->channel, channel->eventq.index, |
1216 | channel->eventq.index + channel->eventq.entries - 1); | 1204 | channel->eventq.index + channel->eventq.entries - 1); |
1217 | 1205 | ||
1218 | /* Pin event queue buffer */ | 1206 | /* Pin event queue buffer */ |
1219 | rc = falcon_init_special_buffer(efx, &channel->eventq); | 1207 | falcon_init_special_buffer(efx, &channel->eventq); |
1220 | if (rc) | ||
1221 | return rc; | ||
1222 | 1208 | ||
1223 | /* Fill event queue with all ones (i.e. empty events) */ | 1209 | /* Fill event queue with all ones (i.e. empty events) */ |
1224 | memset(channel->eventq.addr, 0xff, channel->eventq.len); | 1210 | memset(channel->eventq.addr, 0xff, channel->eventq.len); |
@@ -1232,8 +1218,6 @@ int falcon_init_eventq(struct efx_channel *channel) | |||
1232 | channel->channel); | 1218 | channel->channel); |
1233 | 1219 | ||
1234 | falcon_set_int_moderation(channel); | 1220 | falcon_set_int_moderation(channel); |
1235 | |||
1236 | return 0; | ||
1237 | } | 1221 | } |
1238 | 1222 | ||
1239 | void falcon_fini_eventq(struct efx_channel *channel) | 1223 | void falcon_fini_eventq(struct efx_channel *channel) |
diff --git a/drivers/net/sfc/falcon.h b/drivers/net/sfc/falcon.h index 4cf05d0b5cfa..41b388b65996 100644 --- a/drivers/net/sfc/falcon.h +++ b/drivers/net/sfc/falcon.h | |||
@@ -40,21 +40,21 @@ extern struct efx_nic_type falcon_b_nic_type; | |||
40 | 40 | ||
41 | /* TX data path */ | 41 | /* TX data path */ |
42 | extern int falcon_probe_tx(struct efx_tx_queue *tx_queue); | 42 | extern int falcon_probe_tx(struct efx_tx_queue *tx_queue); |
43 | extern int falcon_init_tx(struct efx_tx_queue *tx_queue); | 43 | extern void falcon_init_tx(struct efx_tx_queue *tx_queue); |
44 | extern void falcon_fini_tx(struct efx_tx_queue *tx_queue); | 44 | extern void falcon_fini_tx(struct efx_tx_queue *tx_queue); |
45 | extern void falcon_remove_tx(struct efx_tx_queue *tx_queue); | 45 | extern void falcon_remove_tx(struct efx_tx_queue *tx_queue); |
46 | extern void falcon_push_buffers(struct efx_tx_queue *tx_queue); | 46 | extern void falcon_push_buffers(struct efx_tx_queue *tx_queue); |
47 | 47 | ||
48 | /* RX data path */ | 48 | /* RX data path */ |
49 | extern int falcon_probe_rx(struct efx_rx_queue *rx_queue); | 49 | extern int falcon_probe_rx(struct efx_rx_queue *rx_queue); |
50 | extern int falcon_init_rx(struct efx_rx_queue *rx_queue); | 50 | extern void falcon_init_rx(struct efx_rx_queue *rx_queue); |
51 | extern void falcon_fini_rx(struct efx_rx_queue *rx_queue); | 51 | extern void falcon_fini_rx(struct efx_rx_queue *rx_queue); |
52 | extern void falcon_remove_rx(struct efx_rx_queue *rx_queue); | 52 | extern void falcon_remove_rx(struct efx_rx_queue *rx_queue); |
53 | extern void falcon_notify_rx_desc(struct efx_rx_queue *rx_queue); | 53 | extern void falcon_notify_rx_desc(struct efx_rx_queue *rx_queue); |
54 | 54 | ||
55 | /* Event data path */ | 55 | /* Event data path */ |
56 | extern int falcon_probe_eventq(struct efx_channel *channel); | 56 | extern int falcon_probe_eventq(struct efx_channel *channel); |
57 | extern int falcon_init_eventq(struct efx_channel *channel); | 57 | extern void falcon_init_eventq(struct efx_channel *channel); |
58 | extern void falcon_fini_eventq(struct efx_channel *channel); | 58 | extern void falcon_fini_eventq(struct efx_channel *channel); |
59 | extern void falcon_remove_eventq(struct efx_channel *channel); | 59 | extern void falcon_remove_eventq(struct efx_channel *channel); |
60 | extern int falcon_process_eventq(struct efx_channel *channel, int rx_quota); | 60 | extern int falcon_process_eventq(struct efx_channel *channel, int rx_quota); |
diff --git a/drivers/net/sfc/rx.c b/drivers/net/sfc/rx.c index 7d2dc20d0ca3..0f805da4ce55 100644 --- a/drivers/net/sfc/rx.c +++ b/drivers/net/sfc/rx.c | |||
@@ -800,7 +800,7 @@ int efx_probe_rx_queue(struct efx_rx_queue *rx_queue) | |||
800 | return rc; | 800 | return rc; |
801 | } | 801 | } |
802 | 802 | ||
803 | int efx_init_rx_queue(struct efx_rx_queue *rx_queue) | 803 | void efx_init_rx_queue(struct efx_rx_queue *rx_queue) |
804 | { | 804 | { |
805 | struct efx_nic *efx = rx_queue->efx; | 805 | struct efx_nic *efx = rx_queue->efx; |
806 | unsigned int max_fill, trigger, limit; | 806 | unsigned int max_fill, trigger, limit; |
@@ -824,7 +824,7 @@ int efx_init_rx_queue(struct efx_rx_queue *rx_queue) | |||
824 | rx_queue->fast_fill_limit = limit; | 824 | rx_queue->fast_fill_limit = limit; |
825 | 825 | ||
826 | /* Set up RX descriptor ring */ | 826 | /* Set up RX descriptor ring */ |
827 | return falcon_init_rx(rx_queue); | 827 | falcon_init_rx(rx_queue); |
828 | } | 828 | } |
829 | 829 | ||
830 | void efx_fini_rx_queue(struct efx_rx_queue *rx_queue) | 830 | void efx_fini_rx_queue(struct efx_rx_queue *rx_queue) |
diff --git a/drivers/net/sfc/rx.h b/drivers/net/sfc/rx.h index 187b1109973c..0e88a9ddc1c6 100644 --- a/drivers/net/sfc/rx.h +++ b/drivers/net/sfc/rx.h | |||
@@ -14,7 +14,7 @@ | |||
14 | 14 | ||
15 | int efx_probe_rx_queue(struct efx_rx_queue *rx_queue); | 15 | int efx_probe_rx_queue(struct efx_rx_queue *rx_queue); |
16 | void efx_remove_rx_queue(struct efx_rx_queue *rx_queue); | 16 | void efx_remove_rx_queue(struct efx_rx_queue *rx_queue); |
17 | int efx_init_rx_queue(struct efx_rx_queue *rx_queue); | 17 | void efx_init_rx_queue(struct efx_rx_queue *rx_queue); |
18 | void efx_fini_rx_queue(struct efx_rx_queue *rx_queue); | 18 | void efx_fini_rx_queue(struct efx_rx_queue *rx_queue); |
19 | 19 | ||
20 | int efx_lro_init(struct net_lro_mgr *lro_mgr, struct efx_nic *efx); | 20 | int efx_lro_init(struct net_lro_mgr *lro_mgr, struct efx_nic *efx); |
diff --git a/drivers/net/sfc/tx.c b/drivers/net/sfc/tx.c index a3a3eddd30b9..cdee7c200d63 100644 --- a/drivers/net/sfc/tx.c +++ b/drivers/net/sfc/tx.c | |||
@@ -443,7 +443,7 @@ int efx_probe_tx_queue(struct efx_tx_queue *tx_queue) | |||
443 | return rc; | 443 | return rc; |
444 | } | 444 | } |
445 | 445 | ||
446 | int efx_init_tx_queue(struct efx_tx_queue *tx_queue) | 446 | void efx_init_tx_queue(struct efx_tx_queue *tx_queue) |
447 | { | 447 | { |
448 | EFX_LOG(tx_queue->efx, "initialising TX queue %d\n", tx_queue->queue); | 448 | EFX_LOG(tx_queue->efx, "initialising TX queue %d\n", tx_queue->queue); |
449 | 449 | ||
@@ -454,7 +454,7 @@ int efx_init_tx_queue(struct efx_tx_queue *tx_queue) | |||
454 | BUG_ON(tx_queue->stopped); | 454 | BUG_ON(tx_queue->stopped); |
455 | 455 | ||
456 | /* Set up TX descriptor ring */ | 456 | /* Set up TX descriptor ring */ |
457 | return falcon_init_tx(tx_queue); | 457 | falcon_init_tx(tx_queue); |
458 | } | 458 | } |
459 | 459 | ||
460 | void efx_release_tx_buffers(struct efx_tx_queue *tx_queue) | 460 | void efx_release_tx_buffers(struct efx_tx_queue *tx_queue) |
diff --git a/drivers/net/sfc/tx.h b/drivers/net/sfc/tx.h index 1526a73b4b51..5e1cc234e42f 100644 --- a/drivers/net/sfc/tx.h +++ b/drivers/net/sfc/tx.h | |||
@@ -15,7 +15,7 @@ | |||
15 | 15 | ||
16 | int efx_probe_tx_queue(struct efx_tx_queue *tx_queue); | 16 | int efx_probe_tx_queue(struct efx_tx_queue *tx_queue); |
17 | void efx_remove_tx_queue(struct efx_tx_queue *tx_queue); | 17 | void efx_remove_tx_queue(struct efx_tx_queue *tx_queue); |
18 | int efx_init_tx_queue(struct efx_tx_queue *tx_queue); | 18 | void efx_init_tx_queue(struct efx_tx_queue *tx_queue); |
19 | void efx_fini_tx_queue(struct efx_tx_queue *tx_queue); | 19 | void efx_fini_tx_queue(struct efx_tx_queue *tx_queue); |
20 | 20 | ||
21 | int efx_hard_start_xmit(struct sk_buff *skb, struct net_device *net_dev); | 21 | int efx_hard_start_xmit(struct sk_buff *skb, struct net_device *net_dev); |