summaryrefslogtreecommitdiffstats
path: root/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c
diff options
context:
space:
mode:
Diffstat (limited to 'target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c')
-rw-r--r--target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c17
1 files changed, 16 insertions, 1 deletions
diff --git a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c
index 9c76544af..eada693e7 100644
--- a/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c
+++ b/target/linux/ar71xx/files/drivers/net/ag71xx/ag71xx_phy.c
@@ -44,9 +44,13 @@ static void ag71xx_phy_link_adjust(struct net_device *dev)
void ag71xx_phy_start(struct ag71xx *ag)
{
+ struct ag71xx_platform_data *pdata = ag71xx_get_pdata(ag);
+
if (ag->phy_dev) {
phy_start(ag->phy_dev);
} else {
+ if (pdata->has_ar7240_switch)
+ ag71xx_ar7240_start(ag);
ag->link = 1;
ag71xx_link_adjust(ag);
}
@@ -54,9 +58,13 @@ void ag71xx_phy_start(struct ag71xx *ag)
void ag71xx_phy_stop(struct ag71xx *ag)
{
+ struct ag71xx_platform_data *pdata = ag71xx_get_pdata(ag);
+
if (ag->phy_dev) {
phy_stop(ag->phy_dev);
} else {
+ if (pdata->has_ar7240_switch)
+ ag71xx_ar7240_stop(ag);
ag->link = 0;
ag71xx_link_adjust(ag);
}
@@ -200,6 +208,9 @@ int ag71xx_phy_connect(struct ag71xx *ag)
mutex_unlock(&ag->mii_bus->mdio_lock);
}
+ if (pdata->has_ar7240_switch)
+ return ag71xx_ar7240_init(ag);
+
if (pdata->phy_mask)
return ag71xx_phy_connect_multi(ag);
@@ -208,6 +219,10 @@ int ag71xx_phy_connect(struct ag71xx *ag)
void ag71xx_phy_disconnect(struct ag71xx *ag)
{
- if (ag->phy_dev)
+ struct ag71xx_platform_data *pdata = ag71xx_get_pdata(ag);
+
+ if (pdata->has_ar7240_switch)
+ ag71xx_ar7240_cleanup(ag);
+ else if (ag->phy_dev)
phy_disconnect(ag->phy_dev);
}