From: Andrew Lunn <andrew@lunn.ch>
To: Duan Andy <fugang.duan@freescale.com>,
Florian Fainelli <f.fainelli@gmail.com>
Cc: David Miller <davem@davemloft.net>,
Cory Tusar <cory.tusar@pid1solutions.com>,
netdev <netdev@vger.kernel.org>
Subject: Re: [PATCHv3 net-next] net: fec: Ensure clocks are enabled while using mdio bus
Date: Tue, 23 Jun 2015 04:52:21 +0200 [thread overview]
Message-ID: <20150623025221.GA11054@lunn.ch> (raw)
In-Reply-To: <BLUPR03MB37330241ECB85BA2131AAA1F5A00@BLUPR03MB373.namprd03.prod.outlook.com>
> > 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?
Florian, as Maintainer of the phy state machine, what do you think
about adding runtime PM to it?
Thanks
Andrew
next prev parent reply other threads:[~2015-06-23 2:58 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-20 18:38 [PATCHv3 net-next] net: fec: Ensure clocks are enabled while using mdio bus Andrew Lunn
2015-06-23 1:25 ` Duan Andy
2015-06-23 2:52 ` Andrew Lunn [this message]
2015-06-23 3:12 ` Duan Andy
2015-06-23 3:43 ` Andrew Lunn
2015-06-23 4:47 ` Duan Andy
2015-06-23 4:46 ` Florian Fainelli
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20150623025221.GA11054@lunn.ch \
--to=andrew@lunn.ch \
--cc=cory.tusar@pid1solutions.com \
--cc=davem@davemloft.net \
--cc=f.fainelli@gmail.com \
--cc=fugang.duan@freescale.com \
--cc=netdev@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).