diff options
author | Trent Piepho <tpiepho@freescale.com> | 2008-11-20 00:52:41 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-11-20 00:52:41 +0100 |
commit | de339c2aa7fea18410b1abeab5674bfbd4073a63 (patch) | |
tree | 07b2d6c08d5fa9b3400fc00a286654dd06b5461a /drivers/net/ipg.c | |
parent | net: jme.c rxdesc.flags is __le16, other missing endian swaps (diff) | |
download | linux-de339c2aa7fea18410b1abeab5674bfbd4073a63.tar.xz linux-de339c2aa7fea18410b1abeab5674bfbd4073a63.zip |
phylib: Fix auto-negotiation restart avoidance
A previous patch, 51e2a3846eab18711f4eb59cd0a4c33054e2980a, made
genphy_config_aneg() not restart aneg by calling genphy_restart_aneg() if
the advertisement hadn't changed.
But, genphy_restart_aneg() doesn't just restart aneg, it may also *enable*
aneg or un-isolate the PHY from the MII (those functions are controlled by
the same register). The code to avoid calling genphy_restart_aneg() didn't
consider this.
So, modify genphy_config_aneg() to also check if the PHY needs to have aneg
enabled or be un-isolated before deciding not to restart aneg.
This caused a problem with certain Davicom PHYs, as that driver isolates
the PHY (why?) before calling genphy_config_aneg() and expects the PHY to
be un-isolated by that function.
Signed-off-by: Trent Piepho <tpiepho@freescale.com>
Reported-by: Scott Wood <scottwood@freescale.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ipg.c')
0 files changed, 0 insertions, 0 deletions