diff options
author | Felix Fietkau <nbd@openwrt.org> | 2014-12-26 12:36:30 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2014-12-26 12:36:30 +0000 |
commit | a96afecf5c1d08c9a7870eedf9e525fbae0bfecf (patch) | |
tree | 441fc7873650f324394b9feca3327165755f72df /target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch | |
parent | d7320d2d8915ae4d49dd602e25be0f567b40ef11 (diff) | |
download | mtk-20170518-a96afecf5c1d08c9a7870eedf9e525fbae0bfecf.zip mtk-20170518-a96afecf5c1d08c9a7870eedf9e525fbae0bfecf.tar.gz mtk-20170518-a96afecf5c1d08c9a7870eedf9e525fbae0bfecf.tar.bz2 |
kernel: backport a few PHY layer fixes from upstream
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
SVN-Revision: 43776
Diffstat (limited to 'target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch')
-rw-r--r-- | target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch b/target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch new file mode 100644 index 0000000..8e25f8c --- /dev/null +++ b/target/linux/generic/patches-3.14/072-net-phy-Check-for-aneg-completion-before-setting-sta.patch @@ -0,0 +1,35 @@ +From: Balakumaran Kannan <kumaran.4353@gmail.com> +Date: Thu, 24 Apr 2014 08:22:47 +0530 +Subject: [PATCH] net phy: Check for aneg completion before setting state to + PHY_RUNNING + +phy_state_machine should check whether auto-negotiatin is completed +before changing phydev->state from PHY_NOLINK to PHY_RUNNING. If +auto-negotiation is not completed phydev->state should be set to +PHY_AN. + +Signed-off-by: Balakumaran Kannan <kumaran.4353@gmail.com> +Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> +Signed-off-by: David S. Miller <davem@davemloft.net> +--- + +--- a/drivers/net/phy/phy.c ++++ b/drivers/net/phy/phy.c +@@ -744,6 +744,17 @@ void phy_state_machine(struct work_struc + break; + + if (phydev->link) { ++ if (AUTONEG_ENABLE == phydev->autoneg) { ++ err = phy_aneg_done(phydev); ++ if (err < 0) ++ break; ++ ++ if (!err) { ++ phydev->state = PHY_AN; ++ phydev->link_timeout = PHY_AN_TIMEOUT; ++ break; ++ } ++ } + phydev->state = PHY_RUNNING; + netif_carrier_on(phydev->attached_dev); + phydev->adjust_link(phydev->attached_dev); |