Received: by 2002:a05:6a10:a841:0:0:0:0 with SMTP id d1csp1345161pxy; Thu, 29 Apr 2021 05:17:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyrqNhcSvhFC5LjNXFNuoHv8s/5GXZWkxaKVeU9Z7DT6Ahn6wP/VxA7rtVYdksLfDPE1425 X-Received: by 2002:aa7:9add:0:b029:260:8c8a:91fb with SMTP id x29-20020aa79add0000b02902608c8a91fbmr33624024pfp.21.1619698659946; Thu, 29 Apr 2021 05:17:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1619698659; cv=none; d=google.com; s=arc-20160816; b=fUFRXbSgSaxMNLiAE0FZ+m3NvojTUs4AMvf1wFvtWB/00Zmd0XUBcHyJ6333r5aV/V 5mbltl5GN4JHCFrYAfZZjDjhoZvYFPknQUvsb1lE5iJjgOLLTnh7aU7FAyX350W4YFv4 7bz2ga7AIiqJjfeEi/mXcG7mqXDw+ToGcCcFCkvAENPV2htYtIiKJSdW+SXedW9T3Qmu MCyszdSGE4LXy29W77o6zLqsPCirBYABBKgrE3CQlLwoEoUqud5ujJyyxvDyDcazyfd6 tEn5pSu7BHbS1OR2J+hiGAapI0HWn0/LCBLFVzpqoAW6EgGY/VckBxeNJFRe/y4/WqcB FhPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:date:message-id:in-reply-to:subject :cc:to:from:user-agent:references:dkim-signature; bh=RHDNDn67MN6JLEq0pltz7iYeAGgFoGfE9CmM1nSQbiM=; b=o0V8KMLATc/i5UEadzU7stTDV/+SpWC9nLvkRhw1FnNM1DhrfAGf7zcNxd8FxuL1XU mybaviDQJsnputavFoKfFlZizEXgP4XM+svmgUuTl0k7gcS+VsomHY1cpE4OJjA9+mFd xViODKJK2UvUxWqXBKu6FtC3kaHgLb9Dk25xixuo225YU50+bPC6n6cxSv9UvA4itIH0 rZ1fSB4iSuna59ur5cMw3kNCKFJ+SWtDrhLKHWsXu4hUIzsNjokG+u+Q2gmuhyF29b6r 07MfOHP9RrCSFzhFrF20UUc+tM+SQ+6gRdr3Zj41Zxa7hTp3v04SJ7ej1m5nOgsksc2e B4bQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=VLz3BHKd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v11si3369879pfu.198.2021.04.29.05.17.26; Thu, 29 Apr 2021 05:17:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20150623.gappssmtp.com header.s=20150623 header.b=VLz3BHKd; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231921AbhD2MRj (ORCPT + 99 others); Thu, 29 Apr 2021 08:17:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39150 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231490AbhD2MRi (ORCPT ); Thu, 29 Apr 2021 08:17:38 -0400 Received: from mail-ej1-x62d.google.com (mail-ej1-x62d.google.com [IPv6:2a00:1450:4864:20::62d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 51774C06138C for ; Thu, 29 Apr 2021 05:16:52 -0700 (PDT) Received: by mail-ej1-x62d.google.com with SMTP id u3so20846100eja.12 for ; Thu, 29 Apr 2021 05:16:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20150623.gappssmtp.com; s=20150623; h=references:user-agent:from:to:cc:subject:in-reply-to:message-id :date:mime-version; bh=RHDNDn67MN6JLEq0pltz7iYeAGgFoGfE9CmM1nSQbiM=; b=VLz3BHKdI7dakRFv9mmsbfTllD7WadxqdT21O1FF3zjQHR/N6QaVylRXAFuabctKcP S1bsSYCBhQP2msbddEU8aX4hizq6OualaavABgrpoFGQQZHebEb5d5OAO4FuTh/aWLG/ u9ySRd6UmiGk9zNRwGeDJ6U/9b8vNd8F0XzKbW2YZkB314aLxEQ3YSvkRH6JoysyEBVr sEYVf58VIKpdKkjoOUS7PHRybE4+2r7m7GpRNrT6lid9ZsfBuGyrLKVmufnpcvzsIzm2 W0yAHRx6boAsSZIN9OA882VkKLiQz7SMzoikULGcw7/GDvEz4oaGPwFnYVg37Imh8xzl Z0Bg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:references:user-agent:from:to:cc:subject :in-reply-to:message-id:date:mime-version; bh=RHDNDn67MN6JLEq0pltz7iYeAGgFoGfE9CmM1nSQbiM=; b=BhmATyJr9vw6tOsa9+IIcaX62XzWcuejNE4fuRTBZGz0qkX1CJuVscxrgzT5SW+Oue 8oJJxlKJXBUdfMpxACpSPS6F6kVjwrDCqiDnRQ6JTZVJNLIDeifS0K8D+KfEqPm7y45D nMU2GtADt0gwc1P2ygwOsfrwHV9KQG+d9GS5Smn3cvJhqQNd/G2ssnjJaZna+X+xDYrz 3MA4eVrXIXiyKgYl4hIBJxziJ6t3iAiMrNLVXAiWa+CYP8oYQwZ9bLwogCwdtxvUJJWe 5nTpm7LyiaecYOCn10TTnizMnQ04ftOYmObqrN7RXMr2GeWq5xXoLE8ESqgVvdLX3Mh2 ZE0Q== X-Gm-Message-State: AOAM530VSfmWeJIo1xGdzRvtQooIUWiiza1631+X9cC5wLsOlZCqh3Ou 2yWb85/pCs7lRsnqY8ZCmx/Z7Q== X-Received: by 2002:a17:906:b5b:: with SMTP id v27mr11944783ejg.40.1619698610904; Thu, 29 Apr 2021 05:16:50 -0700 (PDT) Received: from localhost (82-65-169-74.subs.proxad.net. [82.65.169.74]) by smtp.gmail.com with ESMTPSA id k5sm2441081edk.46.2021.04.29.05.16.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 29 Apr 2021 05:16:50 -0700 (PDT) References: <20210429090325.60970-1-jbrunet@baylibre.com> <979eb290-6fc2-38df-0596-867b82d22226@baylibre.com> <1jim45juf1.fsf@starbuckisacylon.baylibre.com> <0cfc7286-7be6-57ec-8040-a4370d0b4204@baylibre.com> User-agent: mu4e 1.4.15; emacs 27.1 From: Jerome Brunet To: Neil Armstrong Cc: Kevin Hilman , linux-amlogic@lists.infradead.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] clk: meson: g12a: fix gp0 and hifi ranges In-reply-to: <0cfc7286-7be6-57ec-8040-a4370d0b4204@baylibre.com> Message-ID: <1jfsz9jnf2.fsf@starbuckisacylon.baylibre.com> Date: Thu, 29 Apr 2021 14:16:49 +0200 MIME-Version: 1.0 Content-Type: text/plain Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu 29 Apr 2021 at 14:15, Neil Armstrong wrote: > On 29/04/2021 11:45, Jerome Brunet wrote: >> >> On Thu 29 Apr 2021 at 11:20, Neil Armstrong wrote: >> >>> On 29/04/2021 11:03, Jerome Brunet wrote: >>>> While some SoC samples are able to lock with a PLL factor of 55, others >>>> samples can't. ATM, a minimum of 60 appears to work on all the samples >>>> I have tried. >>>> >>>> Even with 60, it sometimes takes a long time for the PLL to eventually >>>> lock. The documentation says that the minimum rate of these PLLs DCO >>>> should be 3GHz, a factor of 125. Let's use that to be on the safe side. >>>> >>>> With factor range changed, the PLL seems to lock quickly (enough) so far. >>>> It is still unclear if the range was the only reason for the delay. >>>> >>>> Fixes: 085a4ea93d54 ("clk: meson: g12a: add peripheral clock controller") >>>> Signed-off-by: Jerome Brunet >>>> --- >>>> drivers/clk/meson/g12a.c | 2 +- >>>> 1 file changed, 1 insertion(+), 1 deletion(-) >>>> >>>> diff --git a/drivers/clk/meson/g12a.c b/drivers/clk/meson/g12a.c >>>> index b080359b4645..a805bac93c11 100644 >>>> --- a/drivers/clk/meson/g12a.c >>>> +++ b/drivers/clk/meson/g12a.c >>>> @@ -1603,7 +1603,7 @@ static struct clk_regmap g12b_cpub_clk_trace = { >>>> }; >>>> >>>> static const struct pll_mult_range g12a_gp0_pll_mult_range = { >>>> - .min = 55, >>>> + .min = 125, >>>> .max = 255, >>>> }; >>>> >>>> >>> >>> I got other issues with GP0 when trying to use it for DSI on VIM3 & VIM3L. >>> >>> I had to do change the following to have it lock correctly and achieve rates usable for MIPI-DSI requested bandwidth: >>> >>> diff --git a/drivers/clk/meson/clk-pll.c b/drivers/clk/meson/clk-pll.c >>> index cde07f7ebad6..897cd6db5c0f 100644 >>> --- a/drivers/clk/meson/clk-pll.c >>> +++ b/drivers/clk/meson/clk-pll.c >>> @@ -391,9 +391,9 @@ static int meson_clk_pll_set_rate(struct clk_hw *hw, unsigned long rate, >>> meson_parm_write(clk->map, &pll->frac, frac); >>> } >>> >>> - /* If the pll is stopped, bail out now */ >>> + /* If the pll is stopped, bail out now * / >>> if (!enabled) >>> - return 0; >>> + return 0;*/ >> >> This enables the PLL everytime set_rate() is called :/ >> >>> >>> if (meson_clk_pll_enable(hw)) { >>> pr_warn("%s: pll did not lock, trying to restore old rate %lu\n", >>> >>> This one is tricky, for DSI the clock rate is set with assigned-clock-rates in DT, but >>> then the GP0 is seen as stopped and then the rate is never set. >> >> Audio does the same - PLL is set and enabled afterward. This has been >> working so far. >> >>> >>> When afterwards we enable the PLL, the rate set in the registers is invalid and never locks, >>> this permits setting the rate in the registers even if the PLL is >>> stopped. >> >> There something to be explained here cause the register have been set >> before bailing out. What is happening ? The pokes before have no effect >> or are the value being reset at another point ? >> >> I understand this need to address this concern but it does not seems >> related to this particular patch. >> >>> >>> diff --git a/drivers/clk/meson/g12a.c b/drivers/clk/meson/g12a.c >>> index 1b0167b8de3b..08174724a115 100644 >>> --- a/drivers/clk/meson/g12a.c >>> +++ b/drivers/clk/meson/g12a.c >>> @@ -1602,8 +1602,8 @@ static struct clk_regmap g12b_cpub_clk_trace = { >>> }; >>> >>> static const struct pll_mult_range g12a_gp0_pll_mult_range = { >>> - .min = 55, >>> - .max = 255, >>> + .min = 120, >>> + .max = 168, >>> }; >>> >>> I had to change the min/max to achieve a stable and functional rate of 720MHz after the ODs. >>> >> >> How about the range provided in here ? This is range documented by AML >> (3GHz < DCO < 6GHz). 168 limits would limit the rate to ~4GHz which is >> way below spec and would negatively impact audio clocks. > > For hifi pll right, not for GP0 ? > Both have the same spec. >>> Neil >>