summaryrefslogtreecommitdiffstats
path: root/target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch
diff options
context:
space:
mode:
authorRoman Yeryomin <roman@advem.lv>2013-05-26 01:02:55 +0300
committerRoman Yeryomin <roman@advem.lv>2013-05-26 01:02:55 +0300
commit342045a35b1981a89e4bc80842b10c065e1050da (patch)
tree4140720b20e8d641c11da882010d6130a75fef21 /target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch
parent7338133dde8238afce34676214b494c8db96689b (diff)
parent1a116ce7818ecee5d167a9c0ebb1a0feca9120e6 (diff)
Merge trunk into realtek-unstable
Conflicts: Config.in feeds.conf.default package/base-files/files/etc/hotplug2-common.rules package/network/config/netifd/files/etc/init.d/network
Diffstat (limited to 'target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch')
-rw-r--r--target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch27
1 files changed, 27 insertions, 0 deletions
diff --git a/target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch b/target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch
new file mode 100644
index 000000000..5d178e627
--- /dev/null
+++ b/target/linux/generic/patches-3.9/703-phy-add-detach-callback-to-struct-phy_driver.patch
@@ -0,0 +1,27 @@
+--- a/drivers/net/phy/phy_device.c
++++ b/drivers/net/phy/phy_device.c
+@@ -612,6 +612,9 @@ EXPORT_SYMBOL(phy_attach);
+ */
+ void phy_detach(struct phy_device *phydev)
+ {
++ if (phydev->drv && phydev->drv->detach)
++ phydev->drv->detach(phydev);
++
+ phydev->attached_dev->phydev = NULL;
+ phydev->attached_dev = NULL;
+
+--- a/include/linux/phy.h
++++ b/include/linux/phy.h
+@@ -432,6 +432,12 @@ struct phy_driver {
+ */
+ int (*did_interrupt)(struct phy_device *phydev);
+
++ /*
++ * Called before an ethernet device is detached
++ * from the PHY.
++ */
++ void (*detach)(struct phy_device *phydev);
++
+ /* Clears up any memory if needed */
+ void (*remove)(struct phy_device *phydev);
+