From: Joachim Foerster Date: Tue, 25 Oct 2011 22:39:57 +0000 (+0000) Subject: altera_tse: m88e1111s: Honor device flags regarding PHY interface mode X-Git-Tag: v2011.12-rc1~428 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=15eb1069663676243a63a916fe482e751cd56deb;p=oweals%2Fu-boot.git altera_tse: m88e1111s: Honor device flags regarding PHY interface mode Note: This is kind of guess work. The current code is preserved for all RGMII related modes. It is different for flags=0 (GMII) and flags=5 (SGMII). The last case, SGMII, is successfully tested on Altera's Terasic DE4. Signed-off-by: Joachim Foerster --- diff --git a/drivers/net/altera_tse.c b/drivers/net/altera_tse.c index afd8e3126c..8b18ad0b0d 100644 --- a/drivers/net/altera_tse.c +++ b/drivers/net/altera_tse.c @@ -583,7 +583,11 @@ static uint mii_m88e1111s_setmode_sr(uint mii_reg, struct altera_tse_priv *priv) { uint mii_data = tse_mdio_read(priv, mii_reg); mii_data &= 0xfff0; - mii_data |= 0xb; + if ((priv->flags >= 1) && (priv->flags <= 4)) + mii_data |= 0xb; + else if (priv->flags == 5) + mii_data |= 0x4; + return mii_data; } @@ -591,7 +595,9 @@ static uint mii_m88e1111s_setmode_cr(uint mii_reg, struct altera_tse_priv *priv) { uint mii_data = tse_mdio_read(priv, mii_reg); mii_data &= ~0x82; - mii_data |= 0x82; + if ((priv->flags >= 1) && (priv->flags <= 4)) + mii_data |= 0x82; + return mii_data; }