aboutsummaryrefslogtreecommitdiffstats
path: root/target
diff options
context:
space:
mode:
authorGabor Juhos <juhosg@openwrt.org>2012-07-05 08:26:39 +0000
committerGabor Juhos <juhosg@openwrt.org>2012-07-05 08:26:39 +0000
commit6b8392eb125419f4edcafbb8db41bcd07fad5be1 (patch)
tree82dc0f90b19754c91bcfb52e1b9bf2cec92a008e /target
parent0fdac1102d33d31fcd59f206f5b1a622de37f9ae (diff)
downloadupstream-6b8392eb125419f4edcafbb8db41bcd07fad5be1.tar.gz
upstream-6b8392eb125419f4edcafbb8db41bcd07fad5be1.tar.bz2
upstream-6b8392eb125419f4edcafbb8db41bcd07fad5be1.zip
generic: ar8216: start aneg on each PHY of the AR8327
SVN-Revision: 32604
Diffstat (limited to 'target')
-rw-r--r--target/linux/generic/files/drivers/net/phy/ar8216.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c
index 698d92dd7d..4df2dbbdb5 100644
--- a/target/linux/generic/files/drivers/net/phy/ar8216.c
+++ b/target/linux/generic/files/drivers/net/phy/ar8216.c
@@ -734,6 +734,7 @@ ar8327_hw_init(struct ar8216_priv *priv)
{
struct ar8327_platform_data *pdata;
struct ar8327_led_cfg *led_cfg;
+ struct mii_bus *bus;
u32 pos, new_pos;
u32 t;
int i;
@@ -770,9 +771,20 @@ ar8327_hw_init(struct ar8216_priv *priv)
priv->write(priv, AR8327_REG_POWER_ON_STRIP, new_pos);
}
- for (i = 0; i < AR8327_NUM_PHYS; i++)
+ bus = priv->phy->bus;
+ for (i = 0; i < AR8327_NUM_PHYS; i++) {
ar8327_phy_fixup(priv, i);
+ /* start aneg on the PHY */
+ mdiobus_write(bus, i, MII_ADVERTISE, ADVERTISE_ALL |
+ ADVERTISE_PAUSE_CAP |
+ ADVERTISE_PAUSE_ASYM);
+ mdiobus_write(bus, i, MII_CTRL1000, ADVERTISE_1000FULL);
+ mdiobus_write(bus, i, MII_BMCR, BMCR_RESET | BMCR_ANENABLE);
+ }
+
+ msleep(1000);
+
return 0;
}