diff options
author | Ben Hutchings <bhutchings@solarflare.com> | 2009-02-27 08:06:12 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-03-02 06:15:02 -0500 |
commit | 7b065f91faf56f5445ba45878ce6c55ea6388bb3 (patch) | |
tree | cc559f0dd678b604394a24c28fcbc25c0893ccad /drivers/net/sfc | |
parent | 22ef02c23a236cb825b13f3335ff05ef5072a03d (diff) |
sfc: Fix test for MDIO read failure
Commit 27dd2caca4eabe7c13a052b7456495ba75535e6a changed
mdio_clause45_check_mmds() to read both DEVS0 and DEVS1 registers and
to combine their values into an unsigned 32-bit mask. This made the
following test for a negative (failure) value useless. Fix it to
check whether either read failed.
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/mdio_10g.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/drivers/net/sfc/mdio_10g.c b/drivers/net/sfc/mdio_10g.c index f9e2f95c3b48..4462fb58a3a9 100644 --- a/drivers/net/sfc/mdio_10g.c +++ b/drivers/net/sfc/mdio_10g.c | |||
@@ -125,24 +125,25 @@ int mdio_clause45_wait_reset_mmds(struct efx_nic *efx, | |||
125 | int mdio_clause45_check_mmds(struct efx_nic *efx, | 125 | int mdio_clause45_check_mmds(struct efx_nic *efx, |
126 | unsigned int mmd_mask, unsigned int fatal_mask) | 126 | unsigned int mmd_mask, unsigned int fatal_mask) |
127 | { | 127 | { |
128 | int mmd = 0, probe_mmd, devs0, devs1; | ||
128 | u32 devices; | 129 | u32 devices; |
129 | int mmd = 0, probe_mmd; | ||
130 | 130 | ||
131 | /* Historically we have probed the PHYXS to find out what devices are | 131 | /* Historically we have probed the PHYXS to find out what devices are |
132 | * present,but that doesn't work so well if the PHYXS isn't expected | 132 | * present,but that doesn't work so well if the PHYXS isn't expected |
133 | * to exist, if so just find the first item in the list supplied. */ | 133 | * to exist, if so just find the first item in the list supplied. */ |
134 | probe_mmd = (mmd_mask & MDIO_MMDREG_DEVS_PHYXS) ? MDIO_MMD_PHYXS : | 134 | probe_mmd = (mmd_mask & MDIO_MMDREG_DEVS_PHYXS) ? MDIO_MMD_PHYXS : |
135 | __ffs(mmd_mask); | 135 | __ffs(mmd_mask); |
136 | devices = (mdio_clause45_read(efx, efx->mii.phy_id, | ||
137 | probe_mmd, MDIO_MMDREG_DEVS0) | | ||
138 | mdio_clause45_read(efx, efx->mii.phy_id, | ||
139 | probe_mmd, MDIO_MMDREG_DEVS1) << 16); | ||
140 | 136 | ||
141 | /* Check all the expected MMDs are present */ | 137 | /* Check all the expected MMDs are present */ |
142 | if (devices < 0) { | 138 | devs0 = mdio_clause45_read(efx, efx->mii.phy_id, |
139 | probe_mmd, MDIO_MMDREG_DEVS0); | ||
140 | devs1 = mdio_clause45_read(efx, efx->mii.phy_id, | ||
141 | probe_mmd, MDIO_MMDREG_DEVS1); | ||
142 | if (devs0 < 0 || devs1 < 0) { | ||
143 | EFX_ERR(efx, "failed to read devices present\n"); | 143 | EFX_ERR(efx, "failed to read devices present\n"); |
144 | return -EIO; | 144 | return -EIO; |
145 | } | 145 | } |
146 | devices = devs0 | (devs1 << 16); | ||
146 | if ((devices & mmd_mask) != mmd_mask) { | 147 | if ((devices & mmd_mask) != mmd_mask) { |
147 | EFX_ERR(efx, "required MMDs not present: got %x, " | 148 | EFX_ERR(efx, "required MMDs not present: got %x, " |
148 | "wanted %x\n", devices, mmd_mask); | 149 | "wanted %x\n", devices, mmd_mask); |