From: Tony Lindgren <tony@atomide.com>
To: Paul Walmsley <paul@pwsan.com>
Cc: linux-omap@vger.kernel.org,
Peter de Schrijver <peter.de-schrijver@nokia.com>,
khilman@deeprootsystems.com
Subject: Re: [PATCH] OMAP3 clock: disable DPLL autoidle while waiting for DPLL to lock
Date: Fri, 21 Nov 2008 14:28:08 -0800 [thread overview]
Message-ID: <20081121222807.GI4927@atomide.com> (raw)
In-Reply-To: <alpine.DEB.2.00.0811141043400.27331@utopia.booyaka.com>
* Paul Walmsley <paul@pwsan.com> [081114 09:46]:
>
> During _omap3_noncore_dpll_lock(), if a DPLL has no active downstream
> clocks and DPLL autoidle is enabled, the DPLL may never lock, since it
> will enter autoidle immediately. To resolve this, disable DPLL
> autoidle while locking the DPLL, and unconditionally wait for the DPLL
> to lock. This fixes some bugs where the kernel would hang when returning
> from retention or return the wrong rate for the DPLL.
>
> This patch is a collaboration with Peter de Schrijver
> <peter.de-schrijver@nokia.com> and Kevin Hilman
> <khilman@deeprootsystems.com>.
Pushing to l-o tree today.
Tony
> Signed-off-by: Paul Walmsley <paul@pwsan.com>
> Cc: Peter de Schrijver <peter.de-schrijver@nokia.com>
> Cc: Kevin Hilman <khilman@deeprootsystems.com>
> ---
> arch/arm/mach-omap2/clock34xx.c | 15 +++++----------
> 1 files changed, 5 insertions(+), 10 deletions(-)
>
> diff --git a/arch/arm/mach-omap2/clock34xx.c b/arch/arm/mach-omap2/clock34xx.c
> index 3a4e160..b8b4494 100644
> --- a/arch/arm/mach-omap2/clock34xx.c
> +++ b/arch/arm/mach-omap2/clock34xx.c
> @@ -163,19 +163,14 @@ static int _omap3_noncore_dpll_lock(struct clk *clk)
>
> ai = omap3_dpll_autoidle_read(clk);
>
> + omap3_dpll_deny_idle(clk);
> +
> _omap3_dpll_write_clken(clk, DPLL_LOCKED);
>
> - if (ai) {
> - /*
> - * If no downstream clocks are enabled, CM_IDLEST bit
> - * may never become active, so don't wait for DPLL to lock.
> - */
> - r = 0;
> + r = _omap3_wait_dpll_status(clk, 1);
> +
> + if (ai)
> omap3_dpll_allow_idle(clk);
> - } else {
> - r = _omap3_wait_dpll_status(clk, 1);
> - omap3_dpll_deny_idle(clk);
> - };
>
> return r;
> }
> --
> To unsubscribe from this list: send the line "unsubscribe linux-omap" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2008-11-21 22:28 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-11-14 17:46 [PATCH] OMAP3 clock: disable DPLL autoidle while waiting for DPLL to lock Paul Walmsley
2008-11-21 22:28 ` Tony Lindgren [this message]
2008-11-21 22:40 ` Kevin Hilman
2008-11-21 23:22 ` Paul Walmsley
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=20081121222807.GI4927@atomide.com \
--to=tony@atomide.com \
--cc=khilman@deeprootsystems.com \
--cc=linux-omap@vger.kernel.org \
--cc=paul@pwsan.com \
--cc=peter.de-schrijver@nokia.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.