Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp2506392rwr; Sat, 6 May 2023 12:27:52 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ6I00TigxckhL9+hqkvKCPTTySEVAJSQirA3mcqrUZ78ubL8nJJWFmfoaQ+fOuJ/TqS7prM X-Received: by 2002:a05:6a00:2d93:b0:63b:89ba:fca1 with SMTP id fb19-20020a056a002d9300b0063b89bafca1mr8652781pfb.10.1683401272444; Sat, 06 May 2023 12:27:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683401272; cv=none; d=google.com; s=arc-20160816; b=dmFQIIvZjGL3K6X3lwqPqbYt2ljdXqfL3gjdUNOeV/kqt+V8xlV5biQgOZe3QiQDtN nbypo+SuJ4USIXfPRxGKChbQVt7hB5MQOuR4DnNo90KwaUnd27WsHOWl2iLfJysbR9Np xOHM6qrsaHHvVLPXZV8DBGT1/LkkFQdFw4IN0hxMEUA4PsAp2VJ7wjC5uaUebpr5ldmP GVknAhSpv6Qggmc6FKGEvOpzHg67O37i+ecYKd0UBUGhyB16+AU/4gtJ8l6X+fU9Wg80 DHRp7vJidc4/h4zPx1GE1F4ogjMAjPaY8c1sBytDVPpIvpDVN+ihOFOiOp1BFhDllWPk wmmg== 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=F+jdPRHPNZecxppiqvpxaH4jO4aRXCVPuKLqtE0Zolk=; b=WqwU09y/Nv5D9dbrTwZbRwl/lM3zhFLVwxOVZUMmOEcm0A0nP2WTufStRKls8EA1EY cHpsx7ujLrLEkqCHdUqgQu3KUk7O7pQnYpxwMN3CHdfNybjRagpYHIjhDBwjcLuF/Q1D q8HoDI9ui0sOeSBYESy1EwXGlMNs49wgxY3oXJoLN9Aj4JZvbrhXHWRwcpFIEhg9PjbL UpjVay0jgS+2mmtjxbPLsDAtiEd6DbbQCjwlVNNn6maSnt/2fPDacyo78woKe53TOgQh eZLx6WRYaqkU4mmVpvb+bBvsB2zdiax905RGRSJzIW3JejvYWUVZDaVc8SmgQ/1TIdWD gSHg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20221208 header.b=ChfCBtxl; 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 bs125-20020a632883000000b0052c2904e37dsi4663154pgb.362.2023.05.06.12.27.38; Sat, 06 May 2023 12:27:52 -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=ChfCBtxl; 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 S229996AbjEFTZo (ORCPT + 99 others); Sat, 6 May 2023 15:25:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:47214 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229655AbjEFTZb (ORCPT ); Sat, 6 May 2023 15:25:31 -0400 Received: from mail-io1-xd2b.google.com (mail-io1-xd2b.google.com [IPv6:2607:f8b0:4864:20::d2b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 80CFE18DD9 for ; Sat, 6 May 2023 12:25:29 -0700 (PDT) Received: by mail-io1-xd2b.google.com with SMTP id ca18e2360f4ac-766692684c6so65055039f.2 for ; Sat, 06 May 2023 12:25:29 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20221208; t=1683401129; x=1685993129; 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=F+jdPRHPNZecxppiqvpxaH4jO4aRXCVPuKLqtE0Zolk=; b=ChfCBtxl2QqV4MVQGPRqPVuqZd5rQiNo/V6xQY7jf09NctjLRvG335IEKcl5mhwvKE Gs1fS3j+XoxB1eQpFGadYrdqo1Lseg8z7qUY/6PL6MdaR4DZqb/VHHHVMvsHGMrOsZP5 hwhopotDnqenbQobyRM8txddusrE9qYdVfzB3Begy337ORRxXzgSw7LgE19gWYPc0UXV OZESW/51WX/wl9m2HWDS9F0aaMyq5t9OLf/2ASOto4qdETfthcGLvqTlf6ujNcq2382e tlKPyb51ygp+qkpsslzbkr1i4M3YYKAAzXEfWzxIwxmSxZg183+kkiWAysTnP48wEgjB hEvQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20221208; t=1683401129; x=1685993129; 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=F+jdPRHPNZecxppiqvpxaH4jO4aRXCVPuKLqtE0Zolk=; b=QLyzd/fX25IKWCxlIC+1FEyAUqaOweoJHtmumF4DNbuLfAffFeHUVPy/20ar8+oOZm Z/XhVIGXKLrZYmeYujSsYu+3/xlr8ZuzEyrZhsjoBG9AN8Nkgza75GguWeNBkRtWNae/ 4qDfbq/uX+t08UKO20aWQpcTPORID5sBZZl/DzqQn0XB+SKcduziLXEYh1rDEnGWxpsk N6hc16oJ4E67unjcjUi0huT7kmC8Ht4YxbQYdTqWf39bOBA5PS/ikKnozBIs1VHEFcI/ JSRYVF+giqxffc2WHKih5v2ldcn4ZF5AMSy9clszKGUHxL8RP5e1YUA2wGRFWvDvCdjQ o9Zg== X-Gm-Message-State: AC+VfDwFh3TcIpuVB7pEYtst4gu8d7awPlS7vdwNamnHmgv8qbGHRTVx jAnOfKTfIowRshutFhEldR5IqRLx3LAacA== X-Received: by 2002:a5e:dd05:0:b0:766:41fa:e26f with SMTP id t5-20020a5edd05000000b0076641fae26fmr3518860iop.10.1683401128704; Sat, 06 May 2023 12:25:28 -0700 (PDT) Received: from aford-B741.lan ([2601:447:d001:897f:5e49:1bed:79d0:5c25]) by smtp.gmail.com with ESMTPSA id z18-20020a05663822b200b0041631393ac9sm847824jas.18.2023.05.06.12.25.27 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 06 May 2023 12:25:28 -0700 (PDT) From: Adam Ford To: dri-devel@lists.freedesktop.org Cc: aford@beaconembedded.com, Adam Ford , 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 , linux-kernel@vger.kernel.org Subject: [PATCH V5 6/6] drm: bridge: samsung-dsim: Support non-burst mode Date: Sat, 6 May 2023 14:24:53 -0500 Message-Id: <20230506192453.725621-7-aford173@gmail.com> X-Mailer: git-send-email 2.39.2 In-Reply-To: <20230506192453.725621-1-aford173@gmail.com> References: <20230506192453.725621-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 The high-speed clock is hard-coded to the burst-clock frequency specified in the device tree. However, when using devices like certain bridge chips without burst mode and varying resolutions and refresh rates, it may be necessary to set the high-speed clock dynamically based on the desired pixel clock for the connected device. This also removes the need to set a clock speed from the device tree for non-burst mode operation, since the pixel clock rate is the rate requested from the attached device like a bridge chip. This should have no impact for people using burst-mode and setting the burst clock rate is still required for those users. If the burst clock is not present, change the error message to dev_info indicating the clock use the pixel clock. Lastly, cache the clock rate configured from samsung_dsim_set_pll in order to properly calculate the blanking regardless of whether or not the burst clock is set. Signed-off-by: Adam Ford Tested-by: Chen-Yu Tsai Tested-by: Frieder Schrempf Reviewed-by: Frieder Schrempf --- drivers/gpu/drm/bridge/samsung-dsim.c | 27 +++++++++++++++++++++------ include/drm/bridge/samsung-dsim.h | 1 + 2 files changed, 22 insertions(+), 6 deletions(-) diff --git a/drivers/gpu/drm/bridge/samsung-dsim.c b/drivers/gpu/drm/bridge/samsung-dsim.c index d19a5c87b749..97872ffb903d 100644 --- a/drivers/gpu/drm/bridge/samsung-dsim.c +++ b/drivers/gpu/drm/bridge/samsung-dsim.c @@ -654,16 +654,28 @@ static unsigned long samsung_dsim_set_pll(struct samsung_dsim *dsi, reg = samsung_dsim_read(dsi, DSIM_STATUS_REG); } while ((reg & DSIM_PLL_STABLE) == 0); + dsi->hs_clock = fout; + return fout; } static int samsung_dsim_enable_clock(struct samsung_dsim *dsi) { - unsigned long hs_clk, byte_clk, esc_clk; + unsigned long hs_clk, byte_clk, esc_clk, pix_clk; unsigned long esc_div; u32 reg; + struct drm_display_mode *m = &dsi->mode; + int bpp = mipi_dsi_pixel_format_to_bpp(dsi->format); + + /* m->clock is in KHz */ + pix_clk = m->clock * 1000; + + /* Use burst_clk_rate if available, otherwise use the pix_clk */ + if (dsi->burst_clk_rate) + hs_clk = samsung_dsim_set_pll(dsi, dsi->burst_clk_rate); + else + hs_clk = samsung_dsim_set_pll(dsi, DIV_ROUND_UP(pix_clk * bpp, dsi->lanes)); - hs_clk = samsung_dsim_set_pll(dsi, dsi->burst_clk_rate); if (!hs_clk) { dev_err(dsi->dev, "failed to configure DSI PLL\n"); return -EFAULT; @@ -952,7 +964,7 @@ static void samsung_dsim_set_display_mode(struct samsung_dsim *dsi) u32 reg; if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO) { - int byte_clk_khz = dsi->burst_clk_rate / 1000 / 8; + int byte_clk_khz = dsi->hs_clock / 1000 / 8; int hfp = (m->hsync_start - m->hdisplay) * byte_clk_khz / m->clock; int hbp = (m->htotal - m->hsync_end) * byte_clk_khz / m->clock; int hsa = (m->hsync_end - m->hsync_start) * byte_clk_khz / m->clock; @@ -1802,10 +1814,13 @@ static int samsung_dsim_parse_dt(struct samsung_dsim *dsi) return PTR_ERR(pll_clk); } + /* If it doesn't exist, use pixel clock instead of failing */ ret = samsung_dsim_of_read_u32(node, "samsung,burst-clock-frequency", - &dsi->burst_clk_rate, 0); - if (ret < 0) - return ret; + &dsi->burst_clk_rate, 1); + if (ret < 0) { + dev_info(dev, "Using pixel clock for HS clock frequency\n"); + dsi->burst_clk_rate = 0; + } ret = samsung_dsim_of_read_u32(node, "samsung,esc-clock-frequency", &dsi->esc_clk_rate, 0); diff --git a/include/drm/bridge/samsung-dsim.h b/include/drm/bridge/samsung-dsim.h index 76ea8a1720cc..14176e6e9040 100644 --- a/include/drm/bridge/samsung-dsim.h +++ b/include/drm/bridge/samsung-dsim.h @@ -94,6 +94,7 @@ struct samsung_dsim { u32 pll_clk_rate; u32 burst_clk_rate; + u32 hs_clock; u32 esc_clk_rate; u32 lanes; u32 mode_flags; -- 2.39.2