提交 b771721a 编写于 作者: H hayeswang 提交者: David S. Miller

net/usb/r815x: avoid to call mdio functions for runtime-suspended device

Don't replace the usb_control_msg() with usbnet_{read,write}_cmd()
which couldn't be called inside suspend/resume callback. Keep the
basic functions unlimited. Instead, using usb_autopm_get_interface()
and usb_autopm_put_interface() in r815x_mdio_{read,write}().
Signed-off-by: NHayes Wang <hayeswang@realtek.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 b2f47377
...@@ -126,11 +126,18 @@ static int ocp_reg_write(struct usbnet *dev, u16 addr, u16 data) ...@@ -126,11 +126,18 @@ static int ocp_reg_write(struct usbnet *dev, u16 addr, u16 data)
static int r815x_mdio_read(struct net_device *netdev, int phy_id, int reg) static int r815x_mdio_read(struct net_device *netdev, int phy_id, int reg)
{ {
struct usbnet *dev = netdev_priv(netdev); struct usbnet *dev = netdev_priv(netdev);
int ret;
if (phy_id != R815x_PHY_ID) if (phy_id != R815x_PHY_ID)
return -EINVAL; return -EINVAL;
return ocp_reg_read(dev, BASE_MII + reg * 2); if (usb_autopm_get_interface(dev->intf) < 0)
return -ENODEV;
ret = ocp_reg_read(dev, BASE_MII + reg * 2);
usb_autopm_put_interface(dev->intf);
return ret;
} }
static static
...@@ -141,7 +148,12 @@ void r815x_mdio_write(struct net_device *netdev, int phy_id, int reg, int val) ...@@ -141,7 +148,12 @@ void r815x_mdio_write(struct net_device *netdev, int phy_id, int reg, int val)
if (phy_id != R815x_PHY_ID) if (phy_id != R815x_PHY_ID)
return; return;
if (usb_autopm_get_interface(dev->intf) < 0)
return;
ocp_reg_write(dev, BASE_MII + reg * 2, val); ocp_reg_write(dev, BASE_MII + reg * 2, val);
usb_autopm_put_interface(dev->intf);
} }
static int r8153_bind(struct usbnet *dev, struct usb_interface *intf) static int r8153_bind(struct usbnet *dev, struct usb_interface *intf)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册