Message ID | 20200214194858.8528-1-scott.branden@broadcom.com (mailing list archive) |
---|---|
State | Mainlined |
Commit | 6f08e98d62799e53c89dbf2c9a49d77e20ca648c |
Headers | show |
Series | net: phy: restore mdio regs in the iproc mdio driver | expand |
On Fri, Feb 14, 2020 at 11:48:58AM -0800, Scott Branden wrote: > From: Arun Parameswaran <arun.parameswaran@broadcom.com> > > The mii management register in iproc mdio block > does not have a reention register so it is lost on suspend. reention? Andrew
On 2/14/20 12:33 PM, Andrew Lunn wrote: > On Fri, Feb 14, 2020 at 11:48:58AM -0800, Scott Branden wrote: >> From: Arun Parameswaran <arun.parameswaran@broadcom.com> >> >> The mii management register in iproc mdio block >> does not have a reention register so it is lost on suspend. > > reention? Retention presumably.
On 2020-02-14 12:37 p.m., Florian Fainelli wrote: > On 2/14/20 12:33 PM, Andrew Lunn wrote: >> On Fri, Feb 14, 2020 at 11:48:58AM -0800, Scott Branden wrote: >>> From: Arun Parameswaran <arun.parameswaran@broadcom.com> >>> >>> The mii management register in iproc mdio block >>> does not have a reention register so it is lost on suspend. >> reention? > Retention presumably. Yes, typo. Will fix commit message.
diff --git a/drivers/net/phy/mdio-bcm-iproc.c b/drivers/net/phy/mdio-bcm-iproc.c index 7e9975d25066..f1ded03f0229 100644 --- a/drivers/net/phy/mdio-bcm-iproc.c +++ b/drivers/net/phy/mdio-bcm-iproc.c @@ -178,6 +178,23 @@ static int iproc_mdio_remove(struct platform_device *pdev) return 0; } +#ifdef CONFIG_PM_SLEEP +int iproc_mdio_resume(struct device *dev) +{ + struct platform_device *pdev = to_platform_device(dev); + struct iproc_mdio_priv *priv = platform_get_drvdata(pdev); + + /* restore the mii clock configuration */ + iproc_mdio_config_clk(priv->base); + + return 0; +} + +static const struct dev_pm_ops iproc_mdio_pm_ops = { + .resume = iproc_mdio_resume +}; +#endif /* CONFIG_PM_SLEEP */ + static const struct of_device_id iproc_mdio_of_match[] = { { .compatible = "brcm,iproc-mdio", }, { /* sentinel */ }, @@ -188,6 +205,9 @@ static struct platform_driver iproc_mdio_driver = { .driver = { .name = "iproc-mdio", .of_match_table = iproc_mdio_of_match, +#ifdef CONFIG_PM_SLEEP + .pm = &iproc_mdio_pm_ops, +#endif }, .probe = iproc_mdio_probe, .remove = iproc_mdio_remove,