Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp701819rdg; Thu, 12 Oct 2023 20:11:15 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHtd33+4zPKa86CpioLzd/RrjvOz/kittSYdhAY5A3+L6R9ckIKdTAvnBOoMdwkCbMxkru5 X-Received: by 2002:a05:690c:2b0f:b0:5a7:b893:6f64 with SMTP id em15-20020a05690c2b0f00b005a7b8936f64mr10259212ywb.16.1697166675562; Thu, 12 Oct 2023 20:11:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697166675; cv=none; d=google.com; s=arc-20160816; b=0JGTdl79y7MGIRPpyaluWFBQt/AeZ14jv/e1p5eaMsZlhVr+K56GGof8edTnf4ODWG zvKuN0CrtulfpxmTtWNByHBxGzjixHTaB7recUr4xbNz10sdkWqtXNtNATY9FoJdJ1TL GgaPqSk4xV6Hdl4w9NUXY98wHabmhtqEbz2fxP+5X9/8FkiEd3lsq4cI6LH4l33Wsx+E JMyUAf8BYVbqIb4Lq0TMSP2UH3/Tb12vEpdzl5gbQOhX7+jgfNO00eUECp4kbVR+9dB8 Uk20/Sjdh8TYtCaugF/E2ZzdoEIotRsIFeTC43gPeNquUIHtg6Qj4ak89O4tcJdu/Uq5 FYsg== 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 :message-id:date:subject:cc:to:from:dkim-signature; bh=TsY2oClvKo7kprulGqoF1UimrGsaQgD/VvrbzM3GhTw=; fh=mr5UvqZFT8bLdAFWgU+qrcf+ch2f78vObBKRWP3GZTY=; b=LuQILsNrMW/ktwJL2E0/AXzRfR74ujQkxeoscXybm/NUxbJ413aFcFRa4ohfHiBaUM 5fDS5QFuoQmXVsu8tG/TSMl3JiaS+wulH/i2VFDOBQE5GMbkkEMb1gxzKqeyZTKgPqVL r6gQQ10L1X7J7XzJdF1UeKxprfbecoO4UVitKieIdZbStM6/CRA2iBpQKkJER6gUUJw6 mTFFRERq3QV8G9f04yLFZ/vL8146jQPNfv2OlBhgrzM3lvtqvwEy065dUdUGGdaf26zn uW6H+MphgL9IG2DVMtgB5hhTVJpckfiUU0Yrblu5/hk0s+MIijO7RDi+Gkjae1du+tfA HCJQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=PUrqbi3m; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 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 howler.vger.email (howler.vger.email. [23.128.96.34]) by mx.google.com with ESMTPS id o4-20020a17090ac70400b0026800178358si2780001pjt.144.2023.10.12.20.11.15 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Oct 2023 20:11:15 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) client-ip=23.128.96.34; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20230601 header.b=PUrqbi3m; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.34 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by howler.vger.email (Postfix) with ESMTP id E79A080ECF94; Thu, 12 Oct 2023 20:11:11 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at howler.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229445AbjJMDK5 (ORCPT + 99 others); Thu, 12 Oct 2023 23:10:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34076 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229436AbjJMDKz (ORCPT ); Thu, 12 Oct 2023 23:10:55 -0400 Received: from mail-io1-xd2e.google.com (mail-io1-xd2e.google.com [IPv6:2607:f8b0:4864:20::d2e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CC97991 for ; Thu, 12 Oct 2023 20:10:52 -0700 (PDT) Received: by mail-io1-xd2e.google.com with SMTP id ca18e2360f4ac-79fe6da0049so66330739f.1 for ; Thu, 12 Oct 2023 20:10:52 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1697166652; x=1697771452; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:from:to:cc:subject:date:message-id:reply-to; bh=TsY2oClvKo7kprulGqoF1UimrGsaQgD/VvrbzM3GhTw=; b=PUrqbi3m8OQ7oHAEsYLnI2dw/vsVL3p1196gqwLQH0blKVa/A+UDXq9Mgn7d4M0a6P z1Zw3zlqkUpkq+iqTJMtP84DaLv6Ty5APtrKYBchlr/n8z6+LMkNnRe080tjjN2l+xNR dVIYlYcT/r1uvkuNiQleCJ0SzXJ94kTS6gKmZkDm7TQ5M/hz4taOqjwBgjd1v1jl4j/8 7O9oEgKEyC4hvZYWCV8HLJBeT1NHqVbjm04H2LdKocJ21pLxGj5HxhW9j1u1l4wgHkXr w0PQ+lUa5E0n5VK7+CfkBuTlA866wgKLtChwTiZte69+Lq13+dKzVAgjeUdCy0iYxkd0 eEpw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1697166652; x=1697771452; h=content-transfer-encoding:mime-version:message-id:date:subject:cc :to:from:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=TsY2oClvKo7kprulGqoF1UimrGsaQgD/VvrbzM3GhTw=; b=nfNheQ65aQZN8WQ20mqOS2h5IUt+MNwOdqzV3ms1oEGHdC8KwjNwPXRxqjyWL+CES2 vS5jbhS/5GXxy/7Sk+k2qSPioZC74AYJ7UGBcpyQg/LZHArLULPzzuJ63G6YddEawdHA b6snzGjsx56+7T8s651T72LBJqCT2t+v2kvnTMp4zDyGkMfjXQ/eEe5H6fId1vAoFnaE TqUb/TPQEMhoentaJTtDIjUdTKX/V1ebGvjawXKJPBdJIlZVCruO12vXm78eFDv5F6hf OjGI7S0rbVZta+8MCA+fcAG5VTvWgmEm+GVCjnEcvnziGOAE+OTIWiAs9czB7KwTjdKa W57g== X-Gm-Message-State: AOJu0YzHsBexohDX4ufFiViexS7z8PHMSsYo7NCej0RrvFxHfbwA/Hup l1THDje8hwTSO5xvRts5bbM= X-Received: by 2002:a05:6602:39a:b0:790:f735:4d30 with SMTP id f26-20020a056602039a00b00790f7354d30mr30694824iov.13.1697166652023; Thu, 12 Oct 2023 20:10:52 -0700 (PDT) Received: from aford-System-Version.lan ([2601:447:d002:5be:4979:b5dc:3d65:edd2]) by smtp.gmail.com with ESMTPSA id n3-20020a5e8c03000000b0079ab2787139sm4691058ioj.7.2023.10.12.20.10.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Oct 2023 20:10:51 -0700 (PDT) From: Adam Ford To: dri-devel@lists.freedesktop.org Cc: aford@beaconembedded.com, marex@denx.de, Adam Ford , Inki Dae , Jagan Teki , Marek Szyprowski , Andrzej Hajda , Neil Armstrong , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , linux-kernel@vger.kernel.org Subject: [RFC] drm: bridge: samsung-dsim: Recalculate timings when rounding HFP up Date: Thu, 12 Oct 2023 22:10:40 -0500 Message-Id: <20231013031040.152282-1-aford173@gmail.com> X-Mailer: git-send-email 2.40.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-0.6 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on howler.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (howler.vger.email [0.0.0.0]); Thu, 12 Oct 2023 20:11:12 -0700 (PDT) When using video sync pulses, the HFP, HBP, and HSA are divided between the available lanes if there is more than one lane. For certain timings and lane configurations, the HFP may not be evenly divisible and it gets rounded down which can cause certain resolutions and refresh rates to not sync. ie. 720p60 on some monitors show hss of 1390 and hdisplay of 1280. This yields an HFP of 110. When taking the HFP of 110 divides along 4 lanes, the result is 27.5 which rounds down to 27 and causes some monitors not to sync. The solultion is to round HFP up by finding the remainder of HFP / the number of lanes and increasing the hsync_start, hsync_end, and htotal to compensate when there is a remainder. Signed-off-by: Adam Ford --- This adds support for 720p60 in the i.MX8M Plus. NXP uses a look-up table in their downstream code to accomplish this. Using this calculation, the driver can adjust without the need for a complicated table and should be flexible for different timings and resolutions depending on the monitor. I don't have a DSI analyzer, and this appears to only work on i.MX8M Plus but not Mini and Nano for some reason, despite their having a similar DSI bridge. diff --git a/drivers/gpu/drm/bridge/samsung-dsim.c b/drivers/gpu/drm/bridge/samsung-dsim.c index be5914caa17d..5564e85f6b63 100644 --- a/drivers/gpu/drm/bridge/samsung-dsim.c +++ b/drivers/gpu/drm/bridge/samsung-dsim.c @@ -1628,6 +1628,26 @@ static int samsung_dsim_atomic_check(struct drm_bridge *bridge, adjusted_mode->flags |= (DRM_MODE_FLAG_PHSYNC | DRM_MODE_FLAG_PVSYNC); } + /* + * When using video sync pulses, the HFP, HBP, and HSA are divided between + * the available lanes if there is more than one lane. For certain + * timings and lane configurations, the HFP may not be evenly divisible. + * This can cause HFP to round down, and it ends up being too small which can + * cause some monitors to not sync properly. In these instances, round HFP up + * and adjust htotal to compensate. Through trial and error, it appears that + * the HBP and HSA do not appear to need the same correction that HFP does. + */ + if (dsi->mode_flags & MIPI_DSI_MODE_VIDEO_SYNC_PULSE && dsi->lanes > 1) { + int hfp = adjusted_mode->hsync_start - adjusted_mode->hdisplay; + int remainder = hfp % dsi->lanes; + + if (remainder) { + adjusted_mode->hsync_start += remainder; + adjusted_mode->hsync_end += remainder; + adjusted_mode->htotal += remainder; + } + } + return 0; } -- 2.40.1