Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp2772691rwd; Mon, 15 May 2023 17:06:50 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ619o/5ZSa/cLT5E4cbOHMP8DeLol3ZXX+UJ+hAkKGe0WSrWZSQzipc7SghLegESqxPK/F0 X-Received: by 2002:a4a:d6d9:0:b0:552:4a83:6e7d with SMTP id j25-20020a4ad6d9000000b005524a836e7dmr5256986oot.7.1684195610216; Mon, 15 May 2023 17:06:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1684195610; cv=none; d=google.com; s=arc-20160816; b=ykDcACgd7g0sJV1uJee1/S3FxaiBk/nZNYSQ0NUJazItFfH9RPHn7iFxiWr35H97KW PVG9FemZ1wqrHBhebtZQGmam7HU7atY02YyVVMMJnBZtfktr/a2Wp1iPrf/3RhsOGKVn S5cDTtIuQh/UDZMRDBavvLL+Prjxh8g89yZiKu+OU2EbnW/JdzYfG8KBCSa29SWyiTXH Jg9Bxr11UyyLwi3D5RScJ8/mgTwhOLKG7RHP+LwDP+sXKNK3aeWja36Trpi9O8lV0/TY W6n60fwWUjR3nLabZxeYJFTcQLGfW7koZ4jQ1jnDsbKN6al2Ml5ShnShls0/CExg2nxX ixDA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=KhmHVm3biAYbsxZZFqn6S1mZ25+9+Btd76fwE2r61yM=; b=fWi8ITKyZl3mIkAVUjU25Zpc22D2NYAqkGh+ho+RTpkM+srgpT1BezKwVoa78xxfPs vLrDOb2FAIVM2HGW9Puq2eKpf/xfA22x41yDKl5KVEGVI+enlNG45YGIMAjYIjLVG2jL PBOtUKtjABoI1IsDTxQBoIt8UtGmjtutLCe//35my6UKAZVahI3E3Ska4wpCaLYU698Y dCdmIKJKZ2rlmJMtZWLP/XwvghPMmVUVuqikKiqIaGMv+kqf2QqNS6xR2KsqZnU9ZKlD 3+PQpZeNMwCy/iMXCV1s6x5yrqavSs+WhWHvzqIiBMP+FuhLheg/+1NGF2Iy6tyxsnQw 3Rig== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=jPFoih2J; 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 n19-20020a056820055300b0054723c85458si2863829ooj.17.2023.05.15.17.06.35; Mon, 15 May 2023 17:06:50 -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=jPFoih2J; 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 S245737AbjEOX5e (ORCPT + 99 others); Mon, 15 May 2023 19:57:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42048 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S245590AbjEOX5a (ORCPT ); Mon, 15 May 2023 19:57:30 -0400 Received: from mail-il1-x136.google.com (mail-il1-x136.google.com [IPv6:2607:f8b0:4864:20::136]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 91D6E7294 for ; Mon, 15 May 2023 16:57:29 -0700 (PDT) Received: by mail-il1-x136.google.com with SMTP id e9e14a558f8ab-332cc0efe88so87750015ab.0 for ; Mon, 15 May 2023 16:57:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1684195049; x=1686787049; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=KhmHVm3biAYbsxZZFqn6S1mZ25+9+Btd76fwE2r61yM=; b=jPFoih2JerTXMPTvzSfu70Qlo1kT35sMk9aeKJmYOIXqS8Uv4sjwsLw26Au/WwdM70 oxFKDJU2QY5iIosliXX3Z2H1Ln5Pj4rLx0ISa0i9FE/S8IrEA7sVz+B4fw4KqdTPDLRg t8uVn3dHwT01yJ9tIjYeWeMbQEdHsYaEJPB7UIE5NoQ+PuKnESv7P7PjyLS69FHtKP55 OIRwJed9MULFFElE4bW6SNMVbDLX8UQdon+5b/TLF2nOzU4oYN1h8jxE0noY9vrh8AC1 ECwrJj4j65zr7MXmQnzv4NlaM3r7ECu61UuHgcV+85Bd4xdMZW8qqpneBtwi91P4UxD+ R5fw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1684195049; x=1686787049; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=KhmHVm3biAYbsxZZFqn6S1mZ25+9+Btd76fwE2r61yM=; b=ZSTsVSn+vkkHIU04AxtegZOuWYHMRCUyQ/zNYnIRqX2Utgu+kMjmRvAw6nV0AI1rWj SNlmyJUT0perr99BQETc/wh0I9uXCTHEUOAFXdq/5oEJXBnc63RpHdtlzShRZtT1EYpF BzE2cVWNHBDhqdxFKhfiL+WVOMD0aKptji0xM6yal4vpgDWY1mvcivgMAI0QbvHs3PFg 6drH1lI4ZT6Fk8BhGbFSftmaN671Cj/MV7TdNVvSgeVp7XEPOz1csaGXtnREOQQbXUW5 s7QsZ0jSpcG3BCwP0esNFe3yMsmuTP6K0cPCbuxKX6kNMUYw0fKdXY9BhnBdJJbendl5 HhoQ== X-Gm-Message-State: AC+VfDxmwpl7BYLqM7S1qMDKuk2JvVe5kLtjHSJdmc8eDGLgtKE1B+Eh iQOFQa9ML9kgRH6TG2+eEaY= X-Received: by 2002:a05:6e02:546:b0:335:542b:aa48 with SMTP id i6-20020a056e02054600b00335542baa48mr20490228ils.19.1684195048768; Mon, 15 May 2023 16:57:28 -0700 (PDT) Received: from aford-B741.lan ([2601:447:d001:897f:61e0:9fee:1bca:ea3c]) by smtp.gmail.com with ESMTPSA id f6-20020a056638112600b00411b5ea8576sm7427851jar.108.2023.05.15.16.57.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 15 May 2023 16:57:28 -0700 (PDT) From: Adam Ford To: dri-devel@lists.freedesktop.org Cc: aford@beaconembedded.com, Adam Ford , Lucas Stach , Chen-Yu Tsai , Frieder Schrempf , Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , David Airlie , Daniel Vetter , Inki Dae , Jagan Teki , Marek Szyprowski , Marek Vasut , linux-kernel@vger.kernel.org Subject: [PATCH V6 2/6] drm: bridge: samsung-dsim: Fix PMS Calculator on imx8m[mnp] Date: Mon, 15 May 2023 18:57:09 -0500 Message-Id: <20230515235713.232939-3-aford173@gmail.com> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20230515235713.232939-1-aford173@gmail.com> References: <20230515235713.232939-1-aford173@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_ENVFROM_END_DIGIT, FREEMAIL_FROM,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE 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 According to Table 13-45 of the i.MX8M Mini Reference Manual, the min and max values for M and the frequency range for the VCO_out calculator were incorrect. This information was contradicted in other parts of the mini, nano and plus manuals. After reaching out to my NXP Rep, when confronting him about discrepencies in the Nano manual, he responded with: "Yes it is definitely wrong, the one that is part of the NOTE in MIPI_DPHY_M_PLLPMS register table against PMS_P, PMS_M and PMS_S is not correct. I will report this to Doc team, the one customer should be take into account is the Table 13-40 DPHY PLL Parameters and the Note above." These updated values also match what is used in the NXP downstream kernel. To fix this, make new variables to hold the min and max values of m and the minimum value of VCO_out, and update the PMS calculator to use these new variables instead of using hard-coded values to keep the backwards compatibility with other parts using this driver. Fixes: 4d562c70c4dc ("drm: bridge: samsung-dsim: Add i.MX8M Mini/Nano support") Signed-off-by: Adam Ford Reviewed-by: Lucas Stach Tested-by: Chen-Yu Tsai Tested-by: Frieder Schrempf Reviewed-by: Frieder Schrempf --- drivers/gpu/drm/bridge/samsung-dsim.c | 22 ++++++++++++++++++++-- include/drm/bridge/samsung-dsim.h | 3 +++ 2 files changed, 23 insertions(+), 2 deletions(-) diff --git a/drivers/gpu/drm/bridge/samsung-dsim.c b/drivers/gpu/drm/bridge/samsung-dsim.c index 2be3b58624c3..bf4b33d2de76 100644 --- a/drivers/gpu/drm/bridge/samsung-dsim.c +++ b/drivers/gpu/drm/bridge/samsung-dsim.c @@ -405,6 +405,9 @@ static const struct samsung_dsim_driver_data exynos3_dsi_driver_data = { .num_bits_resol = 11, .pll_p_offset = 13, .reg_values = reg_values, + .m_min = 41, + .m_max = 125, + .min_freq = 500, }; static const struct samsung_dsim_driver_data exynos4_dsi_driver_data = { @@ -418,6 +421,9 @@ static const struct samsung_dsim_driver_data exynos4_dsi_driver_data = { .num_bits_resol = 11, .pll_p_offset = 13, .reg_values = reg_values, + .m_min = 41, + .m_max = 125, + .min_freq = 500, }; static const struct samsung_dsim_driver_data exynos5_dsi_driver_data = { @@ -429,6 +435,9 @@ static const struct samsung_dsim_driver_data exynos5_dsi_driver_data = { .num_bits_resol = 11, .pll_p_offset = 13, .reg_values = reg_values, + .m_min = 41, + .m_max = 125, + .min_freq = 500, }; static const struct samsung_dsim_driver_data exynos5433_dsi_driver_data = { @@ -441,6 +450,9 @@ static const struct samsung_dsim_driver_data exynos5433_dsi_driver_data = { .num_bits_resol = 12, .pll_p_offset = 13, .reg_values = exynos5433_reg_values, + .m_min = 41, + .m_max = 125, + .min_freq = 500, }; static const struct samsung_dsim_driver_data exynos5422_dsi_driver_data = { @@ -453,6 +465,9 @@ static const struct samsung_dsim_driver_data exynos5422_dsi_driver_data = { .num_bits_resol = 12, .pll_p_offset = 13, .reg_values = exynos5422_reg_values, + .m_min = 41, + .m_max = 125, + .min_freq = 500, }; static const struct samsung_dsim_driver_data imx8mm_dsi_driver_data = { @@ -469,6 +484,9 @@ static const struct samsung_dsim_driver_data imx8mm_dsi_driver_data = { */ .pll_p_offset = 14, .reg_values = imx8mm_dsim_reg_values, + .m_min = 64, + .m_max = 1023, + .min_freq = 1050, }; static const struct samsung_dsim_driver_data * @@ -547,12 +565,12 @@ static unsigned long samsung_dsim_pll_find_pms(struct samsung_dsim *dsi, tmp = (u64)fout * (_p << _s); do_div(tmp, fin); _m = tmp; - if (_m < 41 || _m > 125) + if (_m < driver_data->m_min || _m > driver_data->m_max) continue; tmp = (u64)_m * fin; do_div(tmp, _p); - if (tmp < 500 * MHZ || + if (tmp < driver_data->min_freq * MHZ || tmp > driver_data->max_freq * MHZ) continue; diff --git a/include/drm/bridge/samsung-dsim.h b/include/drm/bridge/samsung-dsim.h index ba5484de2b30..a1a5b2b89a7a 100644 --- a/include/drm/bridge/samsung-dsim.h +++ b/include/drm/bridge/samsung-dsim.h @@ -54,11 +54,14 @@ struct samsung_dsim_driver_data { unsigned int has_freqband:1; unsigned int has_clklane_stop:1; unsigned int num_clks; + unsigned int min_freq; unsigned int max_freq; unsigned int wait_for_reset; unsigned int num_bits_resol; unsigned int pll_p_offset; const unsigned int *reg_values; + u16 m_min; + u16 m_max; }; struct samsung_dsim_host_ops { -- 2.39.2