aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/sfc
diff options
context:
space:
mode:
authorBen Hutchings <bhutchings@solarflare.com>2009-11-25 11:11:19 -0500
committerDavid S. Miller <davem@davemloft.net>2009-11-26 18:59:32 -0500
commit1dfc5ceacd00365a9089e98643f4b26253d5a6aa (patch)
tree41dd6ca72a535d75e331d0df71a6fba26998af17 /drivers/net/sfc
parent26deba501371c215f95624ede81ab5b611fd7d95 (diff)
sfc: Hold MAC lock for longer in efx_init_port()
Although efx_init_port() is only called at probe time and so cannot race with port reconfiguration, most of the functions it calls can expect to be called with the MAC lock held. Signed-off-by: Ben Hutchings <bhutchings@solarflare.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/sfc')
-rw-r--r--drivers/net/sfc/efx.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/drivers/net/sfc/efx.c b/drivers/net/sfc/efx.c
index 4ebad613e6d..155aa1cca36 100644
--- a/drivers/net/sfc/efx.c
+++ b/drivers/net/sfc/efx.c
@@ -737,23 +737,27 @@ static int efx_init_port(struct efx_nic *efx)
737 737
738 EFX_LOG(efx, "init port\n"); 738 EFX_LOG(efx, "init port\n");
739 739
740 mutex_lock(&efx->mac_lock);
741
740 rc = efx->phy_op->init(efx); 742 rc = efx->phy_op->init(efx);
741 if (rc) 743 if (rc)
742 return rc; 744 goto fail1;
743 mutex_lock(&efx->mac_lock);
744 efx->phy_op->reconfigure(efx); 745 efx->phy_op->reconfigure(efx);
745 rc = falcon_switch_mac(efx); 746 rc = falcon_switch_mac(efx);
746 mutex_unlock(&efx->mac_lock);
747 if (rc) 747 if (rc)
748 goto fail; 748 goto fail2;
749 efx->mac_op->reconfigure(efx); 749 efx->mac_op->reconfigure(efx);
750 750
751 efx->port_initialized = true; 751 efx->port_initialized = true;
752 efx_stats_enable(efx); 752 efx_stats_enable(efx);
753
754 mutex_unlock(&efx->mac_lock);
753 return 0; 755 return 0;
754 756
755fail: 757fail2:
756 efx->phy_op->fini(efx); 758 efx->phy_op->fini(efx);
759fail1:
760 mutex_unlock(&efx->mac_lock);
757 return rc; 761 return rc;
758} 762}
759 763