Message ID | 1404809383-5597-1-git-send-email-thomas.petazzoni@free-electrons.com |
---|---|
State | Accepted, archived |
Delegated to: | David Miller |
Headers | show |
From: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Date: Tue, 8 Jul 2014 10:49:43 +0200 > As reported by Maggie Mae Roxas, the mvneta driver doesn't behave > properly in 10 Mbit/s mode. This is due to a misconfiguration of the > MVNETA_GMAC_AUTONEG_CONFIG register: bit MVNETA_GMAC_CONFIG_MII_SPEED > must be set for a 100 Mbit/s speed, but cleared for a 10 Mbit/s speed, > which the driver was not properly doing. This commit adjusts that by > setting the MVNETA_GMAC_CONFIG_MII_SPEED bit only in 100 Mbit/s mode, > and relying on the fact that all the speed related bits of this > register are cleared at the beginning of the mvneta_adjust_link() > function. > > This problem exists since c5aff18204da0 ("net: mvneta: driver for > Marvell Armada 370/XP network unit") which is the commit that > introduced the mvneta driver in the kernel. > > Cc: <stable@vger.kernel.org> # v3.8+ > Fixes: c5aff18204da0 ("net: mvneta: driver for Marvell Armada 370/XP network unit") > Reported-by: Maggie Mae Roxas <maggie.mae.roxas@gmail.com> > Cc: Maggie Mae Roxas <maggie.mae.roxas@gmail.com> > Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> Applied and queued up for -stable, thanks. -- To unsubscribe from this list: send the line "unsubscribe netdev" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/drivers/net/ethernet/marvell/mvneta.c b/drivers/net/ethernet/marvell/mvneta.c index 45beca1..d49f08d 100644 --- a/drivers/net/ethernet/marvell/mvneta.c +++ b/drivers/net/ethernet/marvell/mvneta.c @@ -2529,7 +2529,7 @@ static void mvneta_adjust_link(struct net_device *ndev) if (phydev->speed == SPEED_1000) val |= MVNETA_GMAC_CONFIG_GMII_SPEED; - else + else if (phydev->speed == SPEED_100) val |= MVNETA_GMAC_CONFIG_MII_SPEED; mvreg_write(pp, MVNETA_GMAC_AUTONEG_CONFIG, val);
As reported by Maggie Mae Roxas, the mvneta driver doesn't behave properly in 10 Mbit/s mode. This is due to a misconfiguration of the MVNETA_GMAC_AUTONEG_CONFIG register: bit MVNETA_GMAC_CONFIG_MII_SPEED must be set for a 100 Mbit/s speed, but cleared for a 10 Mbit/s speed, which the driver was not properly doing. This commit adjusts that by setting the MVNETA_GMAC_CONFIG_MII_SPEED bit only in 100 Mbit/s mode, and relying on the fact that all the speed related bits of this register are cleared at the beginning of the mvneta_adjust_link() function. This problem exists since c5aff18204da0 ("net: mvneta: driver for Marvell Armada 370/XP network unit") which is the commit that introduced the mvneta driver in the kernel. Cc: <stable@vger.kernel.org> # v3.8+ Fixes: c5aff18204da0 ("net: mvneta: driver for Marvell Armada 370/XP network unit") Reported-by: Maggie Mae Roxas <maggie.mae.roxas@gmail.com> Cc: Maggie Mae Roxas <maggie.mae.roxas@gmail.com> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com> --- drivers/net/ethernet/marvell/mvneta.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)