Received: by 2002:a05:7412:6592:b0:d7:7d3a:4fe2 with SMTP id m18csp1105792rdg; Fri, 11 Aug 2023 09:52:08 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEzwu0u/qqWFUbTh90te5v5++0jEDBwECzpzRlLU5dT5Ye9UmSLxfXwdMbZ4UBFOj96tzg/ X-Received: by 2002:a05:6a20:4415:b0:12c:3973:800d with SMTP id ce21-20020a056a20441500b0012c3973800dmr7744103pzb.6.1691772728419; Fri, 11 Aug 2023 09:52:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1691772728; cv=none; d=google.com; s=arc-20160816; b=uXWb8YXaJUogWQen7REpPptXFDdhePyEc4T1saP1acHHVpNMGh+uyNs6P0Fe16CzE6 OXrU27YIn4mrUBFuX4uYUazf76L+ffQHiYkf9pWi0v+gcSX71KDxzhFKdnLOeZTkwQXa cucY04g/6kzV1gaySZRKlkDmx4c2R79niSxmFGfKwVhdNVmkkeVG9G5HoeV6Sdq2WICW Y5P3YXp1tCYaY1pTYeEe5n/lGwqF3up0AqKFsPNNgwYd6cGjBIbARx9iq1FwHnoiX5Ui Z7JaqGPBMXmjZrlo8ZC0I665jI9xFk8xCP3NNrU09k4RDMyQT7zHOuG2VlMz13ENtZIL UuJw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=hqzfx48+4bGEQ1sZCe8YnSKBTocZAhGI3MQXtEYWZBE=; fh=3QbqESXJnchgYeOzdjIBlGxddfyGojmAihSJsrm+GQA=; b=R8QJu3sAz/C5TrLkDh6L9IwYKBEgzvzmHBU0kwWeXjZo765yEgUmtNWmojqKZg5pDx 3oEox+3lNXpq9ZffAHbrPvNURREUd0xTkbviPnZg+ljuh4xTe1ACdlr2X+uOY7k41ZGf S/yMKetPUfPsWZTv+Zbj85+wq/9qfKHQztCA9yi5xbSArSCeCHP1b0niYRDM47Z5v/2c UjFNc2egXoPQ2n45pMSVzyV6Gb3vugqI4ZlT7qeLZhp6wh2YrHZdvBeXEMkkHqZZaZHk V03Qjgy3eXp93bRjrDRToIrjs1c49L4Y368vAJtliPlH24WTSP41msgchnA42NgtajI2 wOEA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=pDwdIQtw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id v3-20020a655683000000b005653f3c0f7esi3599001pgs.409.2023.08.11.09.51.55; Fri, 11 Aug 2023 09:52:08 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=pDwdIQtw; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232087AbjHKQXo (ORCPT + 99 others); Fri, 11 Aug 2023 12:23:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39082 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229475AbjHKQXn (ORCPT ); Fri, 11 Aug 2023 12:23:43 -0400 Received: from mail-lf1-x131.google.com (mail-lf1-x131.google.com [IPv6:2a00:1450:4864:20::131]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 73EEC18F for ; Fri, 11 Aug 2023 09:23:42 -0700 (PDT) Received: by mail-lf1-x131.google.com with SMTP id 2adb3069b0e04-4fe426521adso3353895e87.0 for ; Fri, 11 Aug 2023 09:23:42 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1691771020; x=1692375820; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=hqzfx48+4bGEQ1sZCe8YnSKBTocZAhGI3MQXtEYWZBE=; b=pDwdIQtwpAy5gwScoUCpKPDoulw1HZVu9xB39OdbB8j1OoQ/kX6uIGJ90le/tUyo0w BFPJbbk4uNsfSALbk/0tkwFQfpujpmfXyIAoIWrv+EYJ+7g2oo18HOixp3X1Z+KKarFr zNaH3QZ1zqymrJX/U3lmSxpF0VEOVklcwOqmlbIIRP9R44VNWBnrnR/347nCaXLY1AvA z+vZPjzJ7rXNWGjyeli8mBvM4lionUf9jdHqV/CyTdJXn7uGsEfYUBT2zZKUNtJiDeJG sRwvR/bYnNQ9rnr30RzddiNOX2I2GexPqHGQ+pL3nVhQEeTHjFTWiF4gdiBqjxY6Z9Lq //9g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1691771020; x=1692375820; h=content-transfer-encoding:in-reply-to:from:references:cc:to :content-language:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=hqzfx48+4bGEQ1sZCe8YnSKBTocZAhGI3MQXtEYWZBE=; b=Z/r3aITB0i5Tn5MMzL5V5umKtOX69yICI0OYxk3oMJGAIYjJaMS/27lC16fsOV9QpX wTKnbWHK0dwLLxcafisQl3DG7aPzd1qRucbfwWhgUZ/XbfaTF0pYUFPSkhAdjc2OEku5 S0N8EkEDCLwig7l0tY5/mGp8WfL7Up1hM7fKVxag4lHiSX8AB4WzojGDEqNrigfoF3vU cNt1UMMbHEnGv9V5Dxxs1GTU34sbm5d/ayzhsTsLdSbAeZFXyzEN0mbUYo6wERxulCQP +cBtifNWHZHv5VD0hGlEXRljIqiO1xRJs8gsNzP1BTzkNpzj3Bqv22ro8TgsOGds+j4B HBsw== X-Gm-Message-State: AOJu0YwfPQMlsex4xfXVkOKvX0SCiAWcJBUXrTo4Zp+pEUJQJmpVg79f +vogQoLuQFGiH9+Xjd4Lx9k= X-Received: by 2002:a05:6512:2804:b0:4f3:d682:7b1c with SMTP id cf4-20020a056512280400b004f3d6827b1cmr2272410lfb.45.1691771020463; Fri, 11 Aug 2023 09:23:40 -0700 (PDT) Received: from [10.0.0.100] (host-85-29-92-32.kaisa-laajakaista.fi. [85.29.92.32]) by smtp.gmail.com with ESMTPSA id v7-20020ac25587000000b004fe3229e584sm768475lfg.270.2023.08.11.09.23.39 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 11 Aug 2023 09:23:40 -0700 (PDT) Message-ID: <37cf3e0d-5a30-466f-86d3-cda077c3921f@gmail.com> Date: Fri, 11 Aug 2023 19:25:42 +0300 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 03/11] drm/bridge: tc358768: Cleanup PLL calculations Content-Language: en-US To: Tomi Valkeinen , Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , David Airlie , Daniel Vetter , Francesco Dolcini Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, Aradhya Bhatia References: <20230804-tc358768-v1-0-1afd44b7826b@ideasonboard.com> <20230804-tc358768-v1-3-1afd44b7826b@ideasonboard.com> From: =?UTF-8?Q?P=C3=A9ter_Ujfalusi?= In-Reply-To: <20230804-tc358768-v1-3-1afd44b7826b@ideasonboard.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM, RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 04/08/2023 13:44, Tomi Valkeinen wrote: > As is quite common, some of TC358768's PLL register fields are to be > programmed with (value - 1). Specifically, the FBD and PRD, multiplier > and divider, are such fields. > > However, what the driver currently does is that it considers that the > formula used for PLL rate calculation is: > > RefClk * [(FBD + 1)/ (PRD + 1)] * [1 / (2^FRS)] > > where FBD and PRD are values directly from the registers, while a more > sensible way to look at it is: > > RefClk * FBD / PRD * (1 / (2^FRS)) > > and when the FBD and PRD values are written to the registers, they will > be subtracted by one. > > Change the driver accordingly, as it simplifies the PLL code. Reviewed-by: Peter Ujfalusi > > Signed-off-by: Tomi Valkeinen > --- > drivers/gpu/drm/bridge/tc358768.c | 14 +++++++------- > 1 file changed, 7 insertions(+), 7 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/tc358768.c b/drivers/gpu/drm/bridge/tc358768.c > index b668f77673c3..d5831a1236e9 100644 > --- a/drivers/gpu/drm/bridge/tc358768.c > +++ b/drivers/gpu/drm/bridge/tc358768.c > @@ -316,7 +316,7 @@ static int tc358768_calc_pll(struct tc358768_priv *priv, > > target_pll = tc358768_pclk_to_pll(priv, mode->clock * 1000); > > - /* pll_clk = RefClk * [(FBD + 1)/ (PRD + 1)] * [1 / (2^FRS)] */ > + /* pll_clk = RefClk * FBD / PRD * (1 / (2^FRS)) */ > > for (i = 0; i < ARRAY_SIZE(frs_limits); i++) > if (target_pll >= frs_limits[i]) > @@ -336,19 +336,19 @@ static int tc358768_calc_pll(struct tc358768_priv *priv, > best_prd = 0; > best_fbd = 0; > > - for (prd = 0; prd < 16; ++prd) { > - u32 divisor = (prd + 1) * (1 << frs); > + for (prd = 1; prd <= 16; ++prd) { > + u32 divisor = prd * (1 << frs); > u32 fbd; > > - for (fbd = 0; fbd < 512; ++fbd) { > + for (fbd = 1; fbd <= 512; ++fbd) { > u32 pll, diff, pll_in; > > - pll = (u32)div_u64((u64)refclk * (fbd + 1), divisor); > + pll = (u32)div_u64((u64)refclk * fbd, divisor); > > if (pll >= max_pll || pll < min_pll) > continue; > > - pll_in = (u32)div_u64((u64)refclk, prd + 1); > + pll_in = (u32)div_u64((u64)refclk, prd); > if (pll_in < 4000000) > continue; > > @@ -611,7 +611,7 @@ static int tc358768_setup_pll(struct tc358768_priv *priv, > mode->clock * 1000); > > /* PRD[15:12] FBD[8:0] */ > - tc358768_write(priv, TC358768_PLLCTL0, (prd << 12) | fbd); > + tc358768_write(priv, TC358768_PLLCTL0, ((prd - 1) << 12) | (fbd - 1)); > > /* FRS[11:10] LBWS[9:8] CKEN[4] RESETB[1] EN[0] */ > tc358768_write(priv, TC358768_PLLCTL1, > -- Péter