Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp821532rwr; Thu, 20 Apr 2023 06:54:50 -0700 (PDT) X-Google-Smtp-Source: AKy350b022PepFIN+o5LJ/79tXi7B4Vt/1siDCU0nHmLYOWj8MpadszLcwFC2HbtTC2RbX+4rEv6 X-Received: by 2002:aa7:888a:0:b0:637:f1ae:d3e with SMTP id z10-20020aa7888a000000b00637f1ae0d3emr1566832pfe.25.1681998890192; Thu, 20 Apr 2023 06:54:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681998890; cv=none; d=google.com; s=arc-20160816; b=zwq954ijdz760JQbnZZjlFM+8BSkrDskNqfqV1x3BrJrdsUy2bC4SffanLpDI3N2G0 GV/mvqT+BZUB8wgnxfeYUwg+lzRkoul3uYsn057kin25BuQUVqrtdsoFw+UW+roNek+A ZdZi8wMl3Xob7zoBnDPqx6+qdexJvNtAEZFyO5aMbmqH0mGm3Skj4oWHNv9IWs4kvBlp +npNFuFrZIQkOfY34S4PmR9hAcTF4I8D647N1Ds9o2Coq7YubElBMJMUDwCoArY7vuJD hMQDHrTJ4Ym664vIEjAec5Wc/SuuzScv0Q7uXrdGOleCiE2VTQmM/qjapUubVujAhSjt /hHQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent :content-transfer-encoding:references:in-reply-to:date:cc:to:from :subject:message-id; bh=IkCNUohPQC0Kd9eZTCeWNkHNSD0nMNMG48rxXJEq5Js=; b=oL0MG4jTcVadhjEUkXrbXRQxDMdsxi0qmVlJJfb4g5Fo4WxemREw6b68Jx4RZ85VMx 42GfC65uOsjF1LLe2D1IBXHyNY+pjikFaANCMRcdqFKksK5IoGzKoqf0psBWDe7ZfvZx 0YHM+ekAj5Jd3wODsqKYrIBnkfjK3oBP4bmET28hsHxdp7zGVTUUccL9b0fIFna48tJ4 AQ6wfaeJ0mAbhaIGx4ComqDbb42WNfNw4ReBtimQ5cfH9jJ+dyWYOYhzEGG5c7Vuf6zk DnSpnePj/ClhlAGlBh5S6WSdYW7GHJr5kIR+2QIQusjq4CeabApsq7qJbMJXY4rWRbYt 5mUQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x9-20020aa79a49000000b0063b68fa0807si1649103pfj.263.2023.04.20.06.54.36; Thu, 20 Apr 2023 06:54: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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231553AbjDTNnq convert rfc822-to-8bit (ORCPT + 99 others); Thu, 20 Apr 2023 09:43:46 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48096 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231234AbjDTNno (ORCPT ); Thu, 20 Apr 2023 09:43:44 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 684925BA1 for ; Thu, 20 Apr 2023 06:43:36 -0700 (PDT) Received: from ptz.office.stw.pengutronix.de ([2a0a:edc0:0:900:1d::77] helo=[IPv6:::1]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1ppUYu-0001Bj-Uu; Thu, 20 Apr 2023 15:43:01 +0200 Message-ID: <19d2c40180d0b9176e17aa6e91c1e7f36f77f626.camel@pengutronix.de> Subject: Re: [PATCH 1/6] drm: bridge: samsung-dsim: Support multi-lane calculations From: Lucas Stach To: Adam Ford Cc: dri-devel@lists.freedesktop.org, Krzysztof Kozlowski , aford@beaconembedded.com, Laurent Pinchart , Andrzej Hajda , Fabio Estevam , m.szyprowski@samsung.com, marex@denx.de, Robert Foss , David Airlie , Jernej Skrabec , Jagan Teki , NXP Linux Team , devicetree@vger.kernel.org, Daniel Vetter , Jonas Karlman , Sascha Hauer , Inki Dae , Rob Herring , linux-arm-kernel@lists.infradead.org, Neil Armstrong , linux-kernel@vger.kernel.org, Pengutronix Kernel Team , Shawn Guo Date: Thu, 20 Apr 2023 15:42:57 +0200 In-Reply-To: References: <20230415104104.5537-1-aford173@gmail.com> <3e47f0d1017fe4c9f71a5de65f32c6ba1662efe2.camel@pengutronix.de> Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 8BIT User-Agent: Evolution 3.46.4 (3.46.4-1.fc37) MIME-Version: 1.0 X-SA-Exim-Connect-IP: 2a0a:edc0:0:900:1d::77 X-SA-Exim-Mail-From: l.stach@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable 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 Am Donnerstag, dem 20.04.2023 um 08:24 -0500 schrieb Adam Ford: > On Thu, Apr 20, 2023 at 8:06 AM Lucas Stach wrote: > > > > Hi Adam, > > > > Am Mittwoch, dem 19.04.2023 um 05:47 -0500 schrieb Adam Ford: > > > On Mon, Apr 17, 2023 at 6:55 AM Adam Ford wrote: > > > > > > > > On Mon, Apr 17, 2023 at 3:43 AM Lucas Stach wrote: > > > > > > > > > > Hi Adam, > > > > > > > > > > Am Samstag, dem 15.04.2023 um 05:40 -0500 schrieb Adam Ford: > > > > > > If there is more than one lane, the HFP, HBP, and HSA is calculated in > > > > > > bytes/pixel, then they are divided amongst the different lanes with some > > > > > > additional overhead. This is necessary to achieve higher resolutions while > > > > > > keeping the pixel clocks lower as the number of lanes increase. > > > > > > > > > > > > > > > > In the testing I did to come up with my patch "drm: bridge: samsung- > > > > > dsim: fix blanking packet size calculation" the number of lanes didn't > > > > > make any difference. My testing might be flawed, as I could only > > > > > measure the blanking after translation from MIPI DSI to DPI, so I'm > > > > > interested to know what others did here. How did you validate the > > > > > blanking with your patch? Would you have a chance to test my patch and > > > > > see if it works or breaks in your setup? > > > > > > Lucas, > > > > > > I tried your patch instead of mine. Yours is dependent on the > > > hs_clock being always set to the burst clock which is configured by > > > the device tree. I unrolled a bit of my stuff and replaced it with > > > yours. It worked at 1080p, but when I tried a few other resolutions, > > > they did not work. I assume it's because the DSI clock is fixed and > > > not changing based on the pixel clock. In the version I did, I only > > > did that math when the lanes were > 1. In your patch, you divide by 8, > > > and in mine, I fetch the bits-per-pixel (which is 8) and I divide by > > > that just in case the bpp ever changes from 8. Overall, I think our > > > patches basically do the same thing. > > > > The calculations in your and my patch are quite different. I'm not > > taking into account the number of lanes or the MIPI format. I'm basing > > I was looking more at the division by 8 and the overhead correction of 6. > This number 6 also appears in the NXP downstream kernel [1]. I know > Marek V had some concerns about that. > Yea, I don't fully remember the details about the overhead. Need to page that back in. The division by 8 in my patch is just to get from the bit to a byte clock, nothing to do with the MIPI format bits per channel or something like that. > > the blanking size purely on the ratio between MIPI DSI byte clock and > > the DPI interface clock. It's quite counter-intuitive that the host > > would scale the blanking to the number of lanes automatically, but > > still require the MIPI packet offset removed, but that's what my > > measurements showed to produce the correct blanking after translation > > to DPI by the TC358767 bridge chip. > > How many lanes is your DSI interface using? > When I did the measurements to come up with the patch, I varied the number of lanes between 1 and 4. Different number of lanes didn't make a difference. In fact trying to compensate for the number of lanes when calculating the blanking size to program into the controller lead to wildly wrong blanking on the DPI side of the external bridge. > > > > If you dynamically scale the HS clock, then you would need to input the > > real used HS clock to the calculation in my patch, instead of the fixed > > burst mode rate. > > I think what you're saying makes sense. > > The code I originally modeled this from was from the NXP downstream > kernel where they define the calculation as being in words [2]. I am > not saying the NXP code is perfect, but the NXP code works. With this > series, my monitors are able to sync a bunch of different resolutions > from 1080p down to 640x480 and a bunch in between with various refresh > rates too. That was the goal of this series. > > Instead of just using your patch as-is, I will adapt yours to use the > scaled clock to see how it behaves and get back to you. > Thanks, that would be very much appreciated. I also don't assert that my calculation is perfect, as I also don't have any more information and needed to resort to observing the blanking after translation by the external bridge, so I hope we could get some better understanding of how things really work by checking what works for both our systems. > I have > finished reworking the dynamic DPHY settings, and I've fixed up making > the PLL device tree optional. If your patch works, I'll drop my > calculation and just build off what you have to use the scaled HS > clock when I submit the V2 and I'll make sure I CC you. > Thanks, I'm open to re-do my measurements with your new patches. Regards, Lucas > adam > > [1] - https://github.com/nxp-imx/linux-imx/blob/lf-6.1.y/drivers/gpu/drm/bridge/sec-dsim.c#L270 > [2] - https://github.com/nxp-imx/linux-imx/blob/lf-6.1.y/drivers/gpu/drm/bridge/sec-dsim.c#L914 > > > > > Regards, > > Lucas