Commit 45383f52 authored by Roger Chen's avatar Roger Chen Committed by David S. Miller

net: stmmac: dwmac-rk: fixes the gmac resume after PD on/off

GMAC Power Domain(PD) will be disabled during suspend.
That will causes GRF registers reset.
So corresponding GRF registers for GMAC must be setup again.
Signed-off-by: default avatarRoger Chen <roger.chen@rock-chips.com>
Signed-off-by: default avatarCaesar Wang <wxt@rock-chips.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ba289af8
...@@ -853,6 +853,16 @@ static struct rk_priv_data *rk_gmac_setup(struct platform_device *pdev, ...@@ -853,6 +853,16 @@ static struct rk_priv_data *rk_gmac_setup(struct platform_device *pdev,
"rockchip,grf"); "rockchip,grf");
bsp_priv->pdev = pdev; bsp_priv->pdev = pdev;
gmac_clk_init(bsp_priv);
return bsp_priv;
}
static int rk_gmac_powerup(struct rk_priv_data *bsp_priv)
{
int ret;
struct device *dev = &bsp_priv->pdev->dev;
/*rmii or rgmii*/ /*rmii or rgmii*/
if (bsp_priv->phy_iface == PHY_INTERFACE_MODE_RGMII) { if (bsp_priv->phy_iface == PHY_INTERFACE_MODE_RGMII) {
dev_info(dev, "init for RGMII\n"); dev_info(dev, "init for RGMII\n");
...@@ -865,15 +875,6 @@ static struct rk_priv_data *rk_gmac_setup(struct platform_device *pdev, ...@@ -865,15 +875,6 @@ static struct rk_priv_data *rk_gmac_setup(struct platform_device *pdev,
dev_err(dev, "NO interface defined!\n"); dev_err(dev, "NO interface defined!\n");
} }
gmac_clk_init(bsp_priv);
return bsp_priv;
}
static int rk_gmac_powerup(struct rk_priv_data *bsp_priv)
{
int ret;
ret = phy_power_on(bsp_priv, true); ret = phy_power_on(bsp_priv, true);
if (ret) if (ret)
return ret; return ret;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment