diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2017-12-16 00:08:37 +0300 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2017-12-16 00:08:37 +0300 | 
| commit | 7a3c296ae08f9b51e399074d8ef6867d65fbd22b (patch) | |
| tree | b8f9eef7b2c5db64f5f977f67edd7cfaaaeb8a89 /drivers/net/phy/phy_device.c | |
| parent | c36c7a7c4034f2ef35c6aa6821e7c82d9968dba4 (diff) | |
| parent | 043ee1debd0b29c16c4c4b11a348ca667bfe9144 (diff) | |
| download | linux-7a3c296ae08f9b51e399074d8ef6867d65fbd22b.tar.xz | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Pull networking fixes from David Miller:
 1) Clamp timeouts to INT_MAX in conntrack, from Jay Elliot.
 2) Fix broken UAPI for BPF_PROG_TYPE_PERF_EVENT, from Hendrik
    Brueckner.
 3) Fix locking in ieee80211_sta_tear_down_BA_sessions, from Johannes
    Berg.
 4) Add missing barriers to ptr_ring, from Michael S. Tsirkin.
 5) Don't advertise gigabit in sh_eth when not available, from Thomas
    Petazzoni.
 6) Check network namespace when delivering to netlink taps, from Kevin
    Cernekee.
 7) Kill a race in raw_sendmsg(), from Mohamed Ghannam.
 8) Use correct address in TCP md5 lookups when replying to an incoming
    segment, from Christoph Paasch.
 9) Add schedule points to BPF map alloc/free, from Eric Dumazet.
10) Don't allow silly mtu values to be used in ipv4/ipv6 multicast, also
    from Eric Dumazet.
11) Fix SKB leak in tipc, from Jon Maloy.
12) Disable MAC learning on OVS ports of mlxsw, from Yuval Mintz.
13) SKB leak fix in skB_complete_tx_timestamp(), from Willem de Bruijn.
14) Add some new qmi_wwan device IDs, from Daniele Palmas.
15) Fix static key imbalance in ingress qdisc, from Jiri Pirko.
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (76 commits)
  net: qcom/emac: Reduce timeout for mdio read/write
  net: sched: fix static key imbalance in case of ingress/clsact_init error
  net: sched: fix clsact init error path
  ip_gre: fix wrong return value of erspan_rcv
  net: usb: qmi_wwan: add Telit ME910 PID 0x1101 support
  pkt_sched: Remove TC_RED_OFFLOADED from uapi
  net: sched: Move to new offload indication in RED
  net: sched: Add TCA_HW_OFFLOAD
  net: aquantia: Increment driver version
  net: aquantia: Fix typo in ethtool statistics names
  net: aquantia: Update hw counters on hw init
  net: aquantia: Improve link state and statistics check interval callback
  net: aquantia: Fill in multicast counter in ndev stats from hardware
  net: aquantia: Fill ndev stat couters from hardware
  net: aquantia: Extend stat counters to 64bit values
  net: aquantia: Fix hardware DMA stream overload on large MRRS
  net: aquantia: Fix actual speed capabilities reporting
  sock: free skb in skb_complete_tx_timestamp on error
  s390/qeth: update takeover IPs after configuration change
  s390/qeth: lock IP table while applying takeover changes
  ...
Diffstat (limited to 'drivers/net/phy/phy_device.c')
| -rw-r--r-- | drivers/net/phy/phy_device.c | 10 | 
1 files changed, 6 insertions, 4 deletions
| diff --git a/drivers/net/phy/phy_device.c b/drivers/net/phy/phy_device.c index 67f25ac29025..b15b31ca2618 100644 --- a/drivers/net/phy/phy_device.c +++ b/drivers/net/phy/phy_device.c @@ -135,7 +135,9 @@ static int mdio_bus_phy_resume(struct device *dev)  	if (!mdio_bus_phy_may_suspend(phydev))  		goto no_resume; +	mutex_lock(&phydev->lock);  	ret = phy_resume(phydev); +	mutex_unlock(&phydev->lock);  	if (ret < 0)  		return ret; @@ -1026,7 +1028,9 @@ int phy_attach_direct(struct net_device *dev, struct phy_device *phydev,  	if (err)  		goto error; +	mutex_lock(&phydev->lock);  	phy_resume(phydev); +	mutex_unlock(&phydev->lock);  	phy_led_triggers_register(phydev);  	return err; @@ -1157,6 +1161,8 @@ int phy_resume(struct phy_device *phydev)  	struct phy_driver *phydrv = to_phy_driver(phydev->mdio.dev.driver);  	int ret = 0; +	WARN_ON(!mutex_is_locked(&phydev->lock)); +  	if (phydev->drv && phydrv->resume)  		ret = phydrv->resume(phydev); @@ -1639,13 +1645,9 @@ int genphy_resume(struct phy_device *phydev)  {  	int value; -	mutex_lock(&phydev->lock); -  	value = phy_read(phydev, MII_BMCR);  	phy_write(phydev, MII_BMCR, value & ~BMCR_PDOWN); -	mutex_unlock(&phydev->lock); -  	return 0;  }  EXPORT_SYMBOL(genphy_resume); | 
