RE: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures
Dear Jon, Thanks a lot for your reminding. I will submit a new driver patch soon. --- Best regards, Allan Chou -Original Message- From: Jon Hunter [mailto:jonath...@nvidia.com] Sent: Wednesday, November 30, 2016 4:08 PM To: al...@asix.com.tw; fre...@asix.com.tw; dean_jenk...@mentor.com; mark_cra...@mentor.com; da...@davemloft.net; robert.f...@collabora.com; ivec...@redhat.com; john.stu...@linaro.org; vpala...@chromium.org; step...@networkplumber.org; grund...@chromium.org; changch...@gmail.com; and...@lunn.ch; trem...@gmail.com; colin.k...@canonical.com; linux-...@vger.kernel.org; net...@vger.kernel.org; linux-kernel@vger.kernel.org; vpala...@google.com Subject: Re: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures Hi Allan, On 30/11/16 03:03, ASIX_Allan [Office] wrote: > The change fixes AX88772x resume failure by > - Restore incorrect AX88772A PHY registers when resetting > - Need to stop MAC operation when suspending > - Need to restart MII when restoring PHY > > Signed-off-by: Allan Chou <al...@asix.com.tw> > Signed-off-by: Robert Foss <robert.f...@collabora.com> > Tested-by: Robert Foss <robert.f...@collabora.com> > Tested-by: Jon Hunter <jonath...@nvidia.com> > Tested-by: Allan Chou <al...@asix.com.tw> V3 of this patch is already in the current mainline branch. So you need to send a patch on top of V3 (or v4.9-rc7) to get this fixed. Also you should highlight the fact that this is a fix needed for v4.9. Cheers Jon -- nvpublic
RE: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures
Dear Jon, Thanks a lot for your reminding. I will submit a new driver patch soon. --- Best regards, Allan Chou -Original Message- From: Jon Hunter [mailto:jonath...@nvidia.com] Sent: Wednesday, November 30, 2016 4:08 PM To: al...@asix.com.tw; fre...@asix.com.tw; dean_jenk...@mentor.com; mark_cra...@mentor.com; da...@davemloft.net; robert.f...@collabora.com; ivec...@redhat.com; john.stu...@linaro.org; vpala...@chromium.org; step...@networkplumber.org; grund...@chromium.org; changch...@gmail.com; and...@lunn.ch; trem...@gmail.com; colin.k...@canonical.com; linux-...@vger.kernel.org; net...@vger.kernel.org; linux-kernel@vger.kernel.org; vpala...@google.com Subject: Re: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures Hi Allan, On 30/11/16 03:03, ASIX_Allan [Office] wrote: > The change fixes AX88772x resume failure by > - Restore incorrect AX88772A PHY registers when resetting > - Need to stop MAC operation when suspending > - Need to restart MII when restoring PHY > > Signed-off-by: Allan Chou > Signed-off-by: Robert Foss > Tested-by: Robert Foss > Tested-by: Jon Hunter > Tested-by: Allan Chou V3 of this patch is already in the current mainline branch. So you need to send a patch on top of V3 (or v4.9-rc7) to get this fixed. Also you should highlight the fact that this is a fix needed for v4.9. Cheers Jon -- nvpublic
Re: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures
Hi Allan, On 30/11/16 03:03, ASIX_Allan [Office] wrote: > The change fixes AX88772x resume failure by > - Restore incorrect AX88772A PHY registers when resetting > - Need to stop MAC operation when suspending > - Need to restart MII when restoring PHY > > Signed-off-by: Allan Chou> Signed-off-by: Robert Foss > Tested-by: Robert Foss > Tested-by: Jon Hunter > Tested-by: Allan Chou V3 of this patch is already in the current mainline branch. So you need to send a patch on top of V3 (or v4.9-rc7) to get this fixed. Also you should highlight the fact that this is a fix needed for v4.9. Cheers Jon -- nvpublic
Re: [PATCH v4 3/5] net: asix: Fix AX88772x resume failures
Hi Allan, On 30/11/16 03:03, ASIX_Allan [Office] wrote: > The change fixes AX88772x resume failure by > - Restore incorrect AX88772A PHY registers when resetting > - Need to stop MAC operation when suspending > - Need to restart MII when restoring PHY > > Signed-off-by: Allan Chou > Signed-off-by: Robert Foss > Tested-by: Robert Foss > Tested-by: Jon Hunter > Tested-by: Allan Chou V3 of this patch is already in the current mainline branch. So you need to send a patch on top of V3 (or v4.9-rc7) to get this fixed. Also you should highlight the fact that this is a fix needed for v4.9. Cheers Jon -- nvpublic
[PATCH v4 3/5] net: asix: Fix AX88772x resume failures
The change fixes AX88772x resume failure by - Restore incorrect AX88772A PHY registers when resetting - Need to stop MAC operation when suspending - Need to restart MII when restoring PHY Signed-off-by: Allan ChouSigned-off-by: Robert Foss Tested-by: Robert Foss Tested-by: Jon Hunter Tested-by: Allan Chou --- drivers/net/usb/asix_devices.c | 47 +- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/drivers/net/usb/asix_devices.c b/drivers/net/usb/asix_devices.c index ebeb730..083dc2e 100644 --- a/drivers/net/usb/asix_devices.c +++ b/drivers/net/usb/asix_devices.c @@ -35,6 +35,15 @@ #definePHY_MODE_RTL8211CL 0x000C +#define AX88772A_PHY14H0x14 +#define AX88772A_PHY14H_DEFAULT 0x442C + +#define AX88772A_PHY15H0x15 +#define AX88772A_PHY15H_DEFAULT 0x03C8 + +#define AX88772A_PHY16H0x16 +#define AX88772A_PHY16H_DEFAULT 0x4044 + struct ax88172_int_data { __le16 res1; u8 link; @@ -424,7 +433,7 @@ static int ax88772a_hw_reset(struct usbnet *dev, int in_pm) { struct asix_data *data = (struct asix_data *)>data; int ret, embd_phy; - u16 rx_ctl; + u16 rx_ctl, phy14h, phy15h, phy16h; u8 chipcode = 0; ret = asix_write_gpio(dev, AX_GPIO_RSE, 5, in_pm); @@ -482,6 +491,32 @@ static int ax88772a_hw_reset(struct usbnet *dev, int in_pm) ret); goto out; } + } else if ((chipcode & AX_CHIPCODE_MASK) == AX_AX88772A_CHIPCODE) { + /* Check if the PHY registers have default settings */ + phy14h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY14H); + phy15h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY15H); + phy16h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY16H); + + netdev_dbg(dev->net, + "772a_hw_reset: MR20=0x%x MR21=0x%x MR22=0x%x\n", + phy14h, phy15h, phy16h); + + /* Restore PHY registers default setting if not */ + if (phy14h != AX88772A_PHY14H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY14H, +AX88772A_PHY14H_DEFAULT); + if (phy15h != AX88772A_PHY15H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY15H, +AX88772A_PHY15H_DEFAULT); + if (phy16h != AX88772A_PHY16H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY16H, +AX88772A_PHY16H_DEFAULT); } ret = asix_write_cmd(dev, AX_CMD_WRITE_IPG0, @@ -543,6 +578,15 @@ static const struct net_device_ops ax88772_netdev_ops = { static void ax88772_suspend(struct usbnet *dev) { struct asix_common_private *priv = dev->driver_priv; + u16 medium; + + /* Stop MAC operation */ + medium = asix_read_medium_status(dev, 1); + medium &= ~AX_MEDIUM_RE; + asix_write_medium_mode(dev, medium, 1); + + netdev_dbg(dev->net, "ax88772_suspend: medium=0x%04x\n", + asix_read_medium_status(dev, 1)); /* Preserve BMCR for restoring */ priv->presvd_phy_bmcr = @@ -577,6 +621,7 @@ static void ax88772_restore_phy(struct usbnet *dev) asix_mdio_write_nopm(dev->net, dev->mii.phy_id, MII_BMCR, priv->presvd_phy_bmcr); + mii_nway_restart(>mii); priv->presvd_phy_advertise = 0; priv->presvd_phy_bmcr = 0; } -- 2.7.4
[PATCH v4 3/5] net: asix: Fix AX88772x resume failures
The change fixes AX88772x resume failure by - Restore incorrect AX88772A PHY registers when resetting - Need to stop MAC operation when suspending - Need to restart MII when restoring PHY Signed-off-by: Allan Chou Signed-off-by: Robert Foss Tested-by: Robert Foss Tested-by: Jon Hunter Tested-by: Allan Chou --- drivers/net/usb/asix_devices.c | 47 +- 1 file changed, 46 insertions(+), 1 deletion(-) diff --git a/drivers/net/usb/asix_devices.c b/drivers/net/usb/asix_devices.c index ebeb730..083dc2e 100644 --- a/drivers/net/usb/asix_devices.c +++ b/drivers/net/usb/asix_devices.c @@ -35,6 +35,15 @@ #definePHY_MODE_RTL8211CL 0x000C +#define AX88772A_PHY14H0x14 +#define AX88772A_PHY14H_DEFAULT 0x442C + +#define AX88772A_PHY15H0x15 +#define AX88772A_PHY15H_DEFAULT 0x03C8 + +#define AX88772A_PHY16H0x16 +#define AX88772A_PHY16H_DEFAULT 0x4044 + struct ax88172_int_data { __le16 res1; u8 link; @@ -424,7 +433,7 @@ static int ax88772a_hw_reset(struct usbnet *dev, int in_pm) { struct asix_data *data = (struct asix_data *)>data; int ret, embd_phy; - u16 rx_ctl; + u16 rx_ctl, phy14h, phy15h, phy16h; u8 chipcode = 0; ret = asix_write_gpio(dev, AX_GPIO_RSE, 5, in_pm); @@ -482,6 +491,32 @@ static int ax88772a_hw_reset(struct usbnet *dev, int in_pm) ret); goto out; } + } else if ((chipcode & AX_CHIPCODE_MASK) == AX_AX88772A_CHIPCODE) { + /* Check if the PHY registers have default settings */ + phy14h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY14H); + phy15h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY15H); + phy16h = asix_mdio_read_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY16H); + + netdev_dbg(dev->net, + "772a_hw_reset: MR20=0x%x MR21=0x%x MR22=0x%x\n", + phy14h, phy15h, phy16h); + + /* Restore PHY registers default setting if not */ + if (phy14h != AX88772A_PHY14H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY14H, +AX88772A_PHY14H_DEFAULT); + if (phy15h != AX88772A_PHY15H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY15H, +AX88772A_PHY15H_DEFAULT); + if (phy16h != AX88772A_PHY16H_DEFAULT) + asix_mdio_write_nopm(dev->net, dev->mii.phy_id, +AX88772A_PHY16H, +AX88772A_PHY16H_DEFAULT); } ret = asix_write_cmd(dev, AX_CMD_WRITE_IPG0, @@ -543,6 +578,15 @@ static const struct net_device_ops ax88772_netdev_ops = { static void ax88772_suspend(struct usbnet *dev) { struct asix_common_private *priv = dev->driver_priv; + u16 medium; + + /* Stop MAC operation */ + medium = asix_read_medium_status(dev, 1); + medium &= ~AX_MEDIUM_RE; + asix_write_medium_mode(dev, medium, 1); + + netdev_dbg(dev->net, "ax88772_suspend: medium=0x%04x\n", + asix_read_medium_status(dev, 1)); /* Preserve BMCR for restoring */ priv->presvd_phy_bmcr = @@ -577,6 +621,7 @@ static void ax88772_restore_phy(struct usbnet *dev) asix_mdio_write_nopm(dev->net, dev->mii.phy_id, MII_BMCR, priv->presvd_phy_bmcr); + mii_nway_restart(>mii); priv->presvd_phy_advertise = 0; priv->presvd_phy_bmcr = 0; } -- 2.7.4