ag71xx: close a race between the phy state machine and link state
A fast stop/start cycle could leave the ag71xx interrupts and tx engine disabled when using a phy driver with a fixed link and the start/stop happens between two phy state machine polls. Prevent this by always forcing the link down on stop regardless of phy state and having a phy connected. SVN-Revision: 28380
This commit is contained in:
parent
a9d6a59cff
commit
c674c874b7
1 changed files with 7 additions and 3 deletions
|
@ -59,15 +59,19 @@ void ag71xx_phy_start(struct ag71xx *ag)
|
||||||
void ag71xx_phy_stop(struct ag71xx *ag)
|
void ag71xx_phy_stop(struct ag71xx *ag)
|
||||||
{
|
{
|
||||||
struct ag71xx_platform_data *pdata = ag71xx_get_pdata(ag);
|
struct ag71xx_platform_data *pdata = ag71xx_get_pdata(ag);
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
if (ag->phy_dev) {
|
if (ag->phy_dev)
|
||||||
phy_stop(ag->phy_dev);
|
phy_stop(ag->phy_dev);
|
||||||
} else {
|
else if (pdata->has_ar7240_switch)
|
||||||
if (pdata->has_ar7240_switch)
|
|
||||||
ag71xx_ar7240_stop(ag);
|
ag71xx_ar7240_stop(ag);
|
||||||
|
|
||||||
|
spin_lock_irqsave(&ag->lock, flags);
|
||||||
|
if (ag->link) {
|
||||||
ag->link = 0;
|
ag->link = 0;
|
||||||
ag71xx_link_adjust(ag);
|
ag71xx_link_adjust(ag);
|
||||||
}
|
}
|
||||||
|
spin_unlock_irqrestore(&ag->lock, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ag71xx_phy_connect_fixed(struct ag71xx *ag)
|
static int ag71xx_phy_connect_fixed(struct ag71xx *ag)
|
||||||
|
|
Loading…
Reference in a new issue