Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp364596yba; Fri, 12 Apr 2019 05:17:10 -0700 (PDT) X-Google-Smtp-Source: APXvYqz6Sbnv1Lx+4luDAkcZq7Zno9+1E5AeFPl/iP+0LVn7IQ8nSUux5wuUioQLU/oRXtHFm0FJ X-Received: by 2002:a17:902:4301:: with SMTP id i1mr54189456pld.307.1555071430357; Fri, 12 Apr 2019 05:17:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555071430; cv=none; d=google.com; s=arc-20160816; b=cHFXpwA6nP4W9KWfX4EUJohdIetX3m9FMUbL5MyRUSN2GBgR9iF7twzdj7239XcOnf IiCe4ySDTxan3F9W4Ak8CFToXjaO39o+AfXfWzRVmpCFk/qXpvHmJR5KoonYZPABKM13 vfc9jVpolN46dgzWQWzzrCskxxUSPlrKTwY+rL345+DoNq7Da5wVY4iNGFes/EaGzI4q VmMl+xlTGrYNwwRjWtTv/geMkvFrtk5bF3pZReNYEtnkJVfuE0QNk6DErbHGUNr2Dnzh LoLac0cCcwU8JdcZJhenvAWwVB9M4WzXfteIVP8hcXuQWI25luhL1FErMo3ZGIZfKqJl secA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=E/tiZ7Ktew1j87XGkNAOx3lscszUPKApcJFs9FNKRds=; b=S6JYmIjv5GVuM7Vz0UiM6AdEXZCcTpRJYyHJsSTxf3LgQHrjxnvhXCaWbgeH267z2E XGpqd78rJgsSC/nagmIjCyOkyQIF41ZbPY1Fkj4N3XgQb+P2iNJYJJh0xvlEPFpL3OP/ VH1v+Vfh1ZKJiiQrz+dwnbrpvy8xWLcvjYXa/Iah1i2W8ATMkAU32dG5c6+t2t1m3sEd b/QbcbdQBtMCxyMfc26sEDB4412QKt/ITMvkYW3nXneasQCfNI+vOlHxX06fOYmbEt68 uCsja7aCC3JU7EYjr5EU/MC/MpA+CBZo8IA4IY00cl/GZxPs5QaiPb+vfbAbeQ4O4uNM qGxg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b15si32479893pfb.231.2019.04.12.05.16.53; Fri, 12 Apr 2019 05:17:10 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727127AbfDLMQA (ORCPT + 99 others); Fri, 12 Apr 2019 08:16:00 -0400 Received: from gloria.sntech.de ([185.11.138.130]:39608 "EHLO gloria.sntech.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726327AbfDLMP7 (ORCPT ); Fri, 12 Apr 2019 08:15:59 -0400 Received: from ip5f5a6320.dynamic.kabel-deutschland.de ([95.90.99.32] helo=diego.localnet) by gloria.sntech.de with esmtpsa (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.89) (envelope-from ) id 1hEv63-0005RQ-9J; Fri, 12 Apr 2019 14:15:55 +0200 From: Heiko =?ISO-8859-1?Q?St=FCbner?= To: Elaine Zhang Cc: mturquette@baylibre.com, sboyd@kernel.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-rockchip@lists.infradead.org, linux-kernel@vger.kernel.org, xxx@rock-chips.com, xf@rock-chips.com, huangtao@rock-chips.com, dianders@chromium.org, briannorris@chromium.org Subject: Re: [PATCH v1 5/6] clk: rockchip: add pll up and down when change pll freq Date: Fri, 12 Apr 2019 14:15:54 +0200 Message-ID: <5677286.2uEqRd8HI1@diego> In-Reply-To: <1554284649-26764-1-git-send-email-zhangqing@rock-chips.com> References: <1554284549-24916-1-git-send-email-zhangqing@rock-chips.com> <1554284649-26764-1-git-send-email-zhangqing@rock-chips.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Elaine, Am Mittwoch, 3. April 2019, 11:44:09 CEST schrieb Elaine Zhang: > set pll sequence: > ->set pll to slow mode or other plls > ->set pll down > ->set pll params > ->set pll up > ->wait pll lock status > ->set pll to normal mode > > To slove the system error: > wait_pll_lock: timeout waiting for pll to lock > pll_set_params: pll update unsucessful, > trying to restore old params Can you tell me on what soc this was experienced? The patch includes rk3399, but I don't think the CrOS kernel does powerdown the pll when changing the cpu-frequency [added Doug and Brian for clarification and possible testing :-) ] But I did find that the M0 code in ATF does actually power-down the PLL and follow your outline from above. So essentially I'd just like a thumbs up from chromeos people if they have the time. Heiko > Signed-off-by: Elaine Zhang > --- > drivers/clk/rockchip/clk-pll.c | 19 +++++++++++++++++++ > 1 file changed, 19 insertions(+) > > diff --git a/drivers/clk/rockchip/clk-pll.c b/drivers/clk/rockchip/clk-pll.c > index dd0433d4753e..9fe1227e77e9 100644 > --- a/drivers/clk/rockchip/clk-pll.c > +++ b/drivers/clk/rockchip/clk-pll.c > @@ -208,6 +208,11 @@ static int rockchip_rk3036_pll_set_params(struct rockchip_clk_pll *pll, > rate_change_remuxed = 1; > } > > + /* set pll power down */ > + writel(HIWORD_UPDATE(1, > + RK3036_PLLCON1_PWRDOWN, 13), > + pll->reg_base + RK3036_PLLCON(1)); > + > /* update pll values */ > writel_relaxed(HIWORD_UPDATE(rate->fbdiv, RK3036_PLLCON0_FBDIV_MASK, > RK3036_PLLCON0_FBDIV_SHIFT) | > @@ -229,6 +234,10 @@ static int rockchip_rk3036_pll_set_params(struct rockchip_clk_pll *pll, > pllcon |= rate->frac << RK3036_PLLCON2_FRAC_SHIFT; > writel_relaxed(pllcon, pll->reg_base + RK3036_PLLCON(2)); > > + /* set pll power up */ > + writel(HIWORD_UPDATE(0, RK3036_PLLCON1_PWRDOWN, 13), > + pll->reg_base + RK3036_PLLCON(1)); > + > /* wait for the pll to lock */ > ret = rockchip_pll_wait_lock(pll); > if (ret) { > @@ -685,6 +694,11 @@ static int rockchip_rk3399_pll_set_params(struct rockchip_clk_pll *pll, > rate_change_remuxed = 1; > } > > + /* set pll power down */ > + writel(HIWORD_UPDATE(RK3399_PLLCON3_PWRDOWN, > + RK3399_PLLCON3_PWRDOWN, 0), > + pll->reg_base + RK3399_PLLCON(3)); > + > /* update pll values */ > writel_relaxed(HIWORD_UPDATE(rate->fbdiv, RK3399_PLLCON0_FBDIV_MASK, > RK3399_PLLCON0_FBDIV_SHIFT), > @@ -708,6 +722,11 @@ static int rockchip_rk3399_pll_set_params(struct rockchip_clk_pll *pll, > RK3399_PLLCON3_DSMPD_SHIFT), > pll->reg_base + RK3399_PLLCON(3)); > > + /* set pll power up */ > + writel(HIWORD_UPDATE(0, > + RK3399_PLLCON3_PWRDOWN, 0), > + pll->reg_base + RK3399_PLLCON(3)); > + > /* wait for the pll to lock */ > ret = rockchip_rk3399_pll_wait_lock(pll); > if (ret) { >