diff options
Diffstat (limited to 'drivers/net/sfc/falcon_xmac.c')
-rw-r--r-- | drivers/net/sfc/falcon_xmac.c | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/drivers/net/sfc/falcon_xmac.c b/drivers/net/sfc/falcon_xmac.c index bae656dd2c4e..9516452c079c 100644 --- a/drivers/net/sfc/falcon_xmac.c +++ b/drivers/net/sfc/falcon_xmac.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | * Driver for Solarflare Solarstorm network controllers and boards | 2 | * Driver for Solarflare Solarstorm network controllers and boards |
3 | * Copyright 2005-2006 Fen Systems Ltd. | 3 | * Copyright 2005-2006 Fen Systems Ltd. |
4 | * Copyright 2006-2009 Solarflare Communications Inc. | 4 | * Copyright 2006-2010 Solarflare Communications Inc. |
5 | * | 5 | * |
6 | * This program is free software; you can redistribute it and/or modify it | 6 | * This program is free software; you can redistribute it and/or modify it |
7 | * under the terms of the GNU General Public License version 2 as published | 7 | * under the terms of the GNU General Public License version 2 as published |
@@ -16,7 +16,6 @@ | |||
16 | #include "io.h" | 16 | #include "io.h" |
17 | #include "mac.h" | 17 | #include "mac.h" |
18 | #include "mdio_10g.h" | 18 | #include "mdio_10g.h" |
19 | #include "phy.h" | ||
20 | #include "workarounds.h" | 19 | #include "workarounds.h" |
21 | 20 | ||
22 | /************************************************************************** | 21 | /************************************************************************** |
@@ -88,6 +87,7 @@ int falcon_reset_xaui(struct efx_nic *efx) | |||
88 | 87 | ||
89 | static void falcon_ack_status_intr(struct efx_nic *efx) | 88 | static void falcon_ack_status_intr(struct efx_nic *efx) |
90 | { | 89 | { |
90 | struct falcon_nic_data *nic_data = efx->nic_data; | ||
91 | efx_oword_t reg; | 91 | efx_oword_t reg; |
92 | 92 | ||
93 | if ((efx_nic_rev(efx) != EFX_REV_FALCON_B0) || LOOPBACK_INTERNAL(efx)) | 93 | if ((efx_nic_rev(efx) != EFX_REV_FALCON_B0) || LOOPBACK_INTERNAL(efx)) |
@@ -99,7 +99,7 @@ static void falcon_ack_status_intr(struct efx_nic *efx) | |||
99 | 99 | ||
100 | /* We can only use this interrupt to signal the negative edge of | 100 | /* We can only use this interrupt to signal the negative edge of |
101 | * xaui_align [we have to poll the positive edge]. */ | 101 | * xaui_align [we have to poll the positive edge]. */ |
102 | if (efx->xmac_poll_required) | 102 | if (nic_data->xmac_poll_required) |
103 | return; | 103 | return; |
104 | 104 | ||
105 | efx_reado(efx, ®, FR_AB_XM_MGT_INT_MSK); | 105 | efx_reado(efx, ®, FR_AB_XM_MGT_INT_MSK); |
@@ -143,7 +143,7 @@ static bool falcon_xmac_link_ok(struct efx_nic *efx) | |||
143 | efx_mdio_phyxgxs_lane_sync(efx)); | 143 | efx_mdio_phyxgxs_lane_sync(efx)); |
144 | } | 144 | } |
145 | 145 | ||
146 | void falcon_reconfigure_xmac_core(struct efx_nic *efx) | 146 | static void falcon_reconfigure_xmac_core(struct efx_nic *efx) |
147 | { | 147 | { |
148 | unsigned int max_frame_len; | 148 | unsigned int max_frame_len; |
149 | efx_oword_t reg; | 149 | efx_oword_t reg; |
@@ -277,12 +277,14 @@ static bool falcon_xmac_check_fault(struct efx_nic *efx) | |||
277 | 277 | ||
278 | static int falcon_reconfigure_xmac(struct efx_nic *efx) | 278 | static int falcon_reconfigure_xmac(struct efx_nic *efx) |
279 | { | 279 | { |
280 | struct falcon_nic_data *nic_data = efx->nic_data; | ||
281 | |||
280 | falcon_reconfigure_xgxs_core(efx); | 282 | falcon_reconfigure_xgxs_core(efx); |
281 | falcon_reconfigure_xmac_core(efx); | 283 | falcon_reconfigure_xmac_core(efx); |
282 | 284 | ||
283 | falcon_reconfigure_mac_wrapper(efx); | 285 | falcon_reconfigure_mac_wrapper(efx); |
284 | 286 | ||
285 | efx->xmac_poll_required = !falcon_xmac_link_ok_retry(efx, 5); | 287 | nic_data->xmac_poll_required = !falcon_xmac_link_ok_retry(efx, 5); |
286 | falcon_ack_status_intr(efx); | 288 | falcon_ack_status_intr(efx); |
287 | 289 | ||
288 | return 0; | 290 | return 0; |
@@ -350,15 +352,17 @@ static void falcon_update_stats_xmac(struct efx_nic *efx) | |||
350 | 352 | ||
351 | void falcon_poll_xmac(struct efx_nic *efx) | 353 | void falcon_poll_xmac(struct efx_nic *efx) |
352 | { | 354 | { |
355 | struct falcon_nic_data *nic_data = efx->nic_data; | ||
356 | |||
353 | if (!EFX_WORKAROUND_5147(efx) || !efx->link_state.up || | 357 | if (!EFX_WORKAROUND_5147(efx) || !efx->link_state.up || |
354 | !efx->xmac_poll_required) | 358 | !nic_data->xmac_poll_required) |
355 | return; | 359 | return; |
356 | 360 | ||
357 | efx->xmac_poll_required = !falcon_xmac_link_ok_retry(efx, 1); | 361 | nic_data->xmac_poll_required = !falcon_xmac_link_ok_retry(efx, 1); |
358 | falcon_ack_status_intr(efx); | 362 | falcon_ack_status_intr(efx); |
359 | } | 363 | } |
360 | 364 | ||
361 | struct efx_mac_operations falcon_xmac_operations = { | 365 | const struct efx_mac_operations falcon_xmac_operations = { |
362 | .reconfigure = falcon_reconfigure_xmac, | 366 | .reconfigure = falcon_reconfigure_xmac, |
363 | .update_stats = falcon_update_stats_xmac, | 367 | .update_stats = falcon_update_stats_xmac, |
364 | .check_fault = falcon_xmac_check_fault, | 368 | .check_fault = falcon_xmac_check_fault, |