aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/phy.h
diff options
context:
space:
mode:
authorBrad Mouring <brad.mouring@ni.com>2018-03-08 16:23:03 -0600
committerDavid S. Miller <davem@davemloft.net>2018-03-12 10:33:07 -0400
commita2c054a896b8ac794ddcfc7c92e2dc7ec4ed4ed5 (patch)
tree14ae44931e189f9d54045bb1f4b8c8a1ddf72071 /include/linux/phy.h
parentopenvswitch: meter: fix the incorrect calculation of max delta_t (diff)
downloadlinux-dev-a2c054a896b8ac794ddcfc7c92e2dc7ec4ed4ed5.tar.xz
linux-dev-a2c054a896b8ac794ddcfc7c92e2dc7ec4ed4ed5.zip
net: phy: Tell caller result of phy_change()
In 664fcf123a30e (net: phy: Threaded interrupts allow some simplification) the phy_interrupt system was changed to use a traditional threaded interrupt scheme instead of a workqueue approach. With this change, the phy status check moved into phy_change, which did not report back to the caller whether or not the interrupt was handled. This means that, in the case of a shared phy interrupt, only the first phydev's interrupt registers are checked (since phy_interrupt() would always return IRQ_HANDLED). This leads to interrupt storms when it is a secondary device that's actually the interrupt source. Signed-off-by: Brad Mouring <brad.mouring@ni.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux/phy.h')
-rw-r--r--include/linux/phy.h1
1 files changed, 0 insertions, 1 deletions
diff --git a/include/linux/phy.h b/include/linux/phy.h
index d7069539f351..b260fb336b25 100644
--- a/include/linux/phy.h
+++ b/include/linux/phy.h
@@ -1012,7 +1012,6 @@ int phy_driver_register(struct phy_driver *new_driver, struct module *owner);
int phy_drivers_register(struct phy_driver *new_driver, int n,
struct module *owner);
void phy_state_machine(struct work_struct *work);
-void phy_change(struct phy_device *phydev);
void phy_change_work(struct work_struct *work);
void phy_mac_interrupt(struct phy_device *phydev);
void phy_start_machine(struct phy_device *phydev);