[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20150623034356.GB11054@lunn.ch>
Date: Tue, 23 Jun 2015 05:43:56 +0200
From: Andrew Lunn <andrew@...n.ch>
To: Duan Andy <fugang.duan@...escale.com>
Cc: Florian Fainelli <f.fainelli@...il.com>,
David Miller <davem@...emloft.net>,
Cory Tusar <cory.tusar@...1solutions.com>,
netdev <netdev@...r.kernel.org>
Subject: Re: [PATCHv3 net-next] net: fec: Ensure clocks are enabled while
using mdio bus
On Tue, Jun 23, 2015 at 03:12:15AM +0000, Duan Andy wrote:
> From: Andrew Lunn <andrew@...n.ch> Sent: Tuesday, June 23, 2015 10:52 AM
> > To: Duan Fugang-B38611; Florian Fainelli
> > Cc: David Miller; Cory Tusar; netdev
> > Subject: Re: [PATCHv3 net-next] net: fec: Ensure clocks are enabled while
> > using mdio bus
> >
> > > > int mii_id, int regnum) {
> > > > struct fec_enet_private *fep = bus->priv;
> > > > unsigned long time_left;
> > > > + int ret;
> > > > +
> > > > + ret = clk_prepare_enable(fep->clk_ipg);
> > > > + if (ret)
> > > > + return ret;
> > > >
> > > > fep->mii_timeout = 0;
> > > > init_completion(&fep->mdio_done);
> > > > @@ -1779,11 +1785,14 @@ static int fec_enet_mdio_read(struct mii_bus
> > > > *bus, int mii_id, int regnum)
> > > > if (time_left == 0) {
> > > > fep->mii_timeout = 1;
> > > > netdev_err(fep->netdev, "MDIO read timeout\n");
> > > > + clk_disable_unprepare(fep->clk_ipg);
> > > > return -ETIMEDOUT;
> > > > }
> > > >
> > > > - /* return value */
> > > > - return FEC_MMFR_DATA(readl(fep->hwp + FEC_MII_DATA));
> > > > + ret = FEC_MMFR_DATA(readl(fep->hwp + FEC_MII_DATA));
> > > > + clk_disable_unprepare(fep->clk_ipg);
> > > > +
> > > > + return ret;
> > > > }
> > > >
> > >
> >
> > > I suggest you use runtime pm to enable/disable clock for performance
> > > consideration. Not every time for mdio bus access needs to
> > > enable/disable clock.
> >
> > Can you explain that some more. When are you suggesting doing a runtime
> > enable/disable? Given the current DSA architecture, i would probably do a
> > runtime enable as soon as i lookup the mdio bus, and never do a runtime
> > disable. Also, how would you include this runtime pm into the phy state
> > machine which is going to be polling your mdio bus around once per second
> > for normal phys?
> >
>
> You can do it like this:
>
> #define FEC_MDIO_PM_TIMEOUT 100 /* ms */
>
> static int fec_probe(struct platform_device *pdev)
> {
> ...
> pm_runtime_enable(&pdev->dev);
> pm_runtime_set_autosuspend_delay(&pdev->dev, FEC_MDIO_PM_TIMEOUT);
> pm_runtime_use_autosuspend(&pdev->dev);
> ...
> }
>
>
> static int fec_enet_mdio_read(struct mii_bus *bus, int mii_id, int regnum)
> {
> ...
> pm_runtime_get_sync(dev);
>
> ...
>
> pm_runtime_mark_last_busy(dev);
> pm_runtime_put_autosuspend(dev);
> }
Isn't this heavier than clk_prepare_enable()/clk_disable_unprepare()?
The clock is only going to be enabled/disabled before the interface is
opened(). Once it is open, the IGP clock is always running, so these
clock operations just become simple reference counts. But the runtime
operations you are suggesting will be doing lots of stuff after open
as well as before open.
Andrew
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
Powered by blists - more mailing lists