X-Git-Url: http://git.openwrt.org/?a=blobdiff_plain;f=target%2Flinux%2Fgeneric%2Fpatches-4.1%2F702-phy_add_aneg_done_function.patch;fp=target%2Flinux%2Fgeneric%2Fpatches-4.1%2F702-phy_add_aneg_done_function.patch;h=d383c5ae7908cbbb88e0ae3b61c36118a7029d67;hb=a0c49ef46f7caf5eb02c635d446218201008ecff;hp=0000000000000000000000000000000000000000;hpb=518ab154e059c9f39684f8c78159c9caf333716b;p=openwrt%2Fopenwrt.git diff --git a/target/linux/generic/patches-4.1/702-phy_add_aneg_done_function.patch b/target/linux/generic/patches-4.1/702-phy_add_aneg_done_function.patch new file mode 100644 index 0000000000..d383c5ae79 --- /dev/null +++ b/target/linux/generic/patches-4.1/702-phy_add_aneg_done_function.patch @@ -0,0 +1,27 @@ +--- a/include/linux/phy.h ++++ b/include/linux/phy.h +@@ -489,6 +489,12 @@ struct phy_driver { + /* Determines the negotiated speed and duplex */ + int (*read_status)(struct phy_device *phydev); + ++ /* ++ * Update the value in phydev->link to reflect the ++ * current link value ++ */ ++ int (*update_link)(struct phy_device *phydev); ++ + /* Clears any pending interrupts */ + int (*ack_interrupt)(struct phy_device *phydev); + +--- a/drivers/net/phy/phy_device.c ++++ b/drivers/net/phy/phy_device.c +@@ -928,6 +928,9 @@ int genphy_update_link(struct phy_device + { + int status; + ++ if (phydev->drv->update_link) ++ return phydev->drv->update_link(phydev); ++ + /* Do a fake read */ + status = phy_read(phydev, MII_BMSR); + if (status < 0)