Received: by 2002:a05:7412:bb8d:b0:d7:7d3a:4fe2 with SMTP id js13csp2159477rdb; Thu, 17 Aug 2023 12:28:17 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFtgi4jOagywbXBqNAclfPRlX7u9bOj1qs1kKA9leB41ANaxTjcCDlhsyes3uxy65Wi3M4L X-Received: by 2002:aa7:d34f:0:b0:522:29ec:3e0a with SMTP id m15-20020aa7d34f000000b0052229ec3e0amr529041edr.28.1692300497548; Thu, 17 Aug 2023 12:28:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1692300497; cv=none; d=google.com; s=arc-20160816; b=AGtS6bRX74XMFG/aBxN/v/k61EhpqyDN/y5enj1NhzolPH7BjGZI5nMjx9q7BKyq2z oB0ox+tYFQ9VEEz38zbYpd6wJXC5N2h6yFk8KQ+7KkDI016kglvyiZJSi/UsCIGh4FbH UPr8HxkbSmsgFe2LvAFRfecTgL1BQZ0IcO7sdtvgV7VN62xNEH/yeVdR+v696ikPqECT IIDC6Bw9YJud1k98NJoDmyAMMQ5Nr1Bue+3YT2mfqMx0ExggEuDuy/GHzUVt/g9hXDAW e/BxuiU6wLT4GMqKpK1A4rkaAViaZsKakBX3aQYHtaFrpJh0oTQ6I66GVHzCCdjWY6SH bIfQ== 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; bh=Pzh+7hhthbGC6tyiCcoX9pDbq63YN5dsHTvGRrHP9tQ=; fh=OmmZDJEp3pl7jaFV8O2/yN66VkuJIFqajAiD2ZUHFno=; b=a5I2bXUXn4Fi7vog7BgPgOuiDEA+y9Ju+zEgU2FC+LOY+/v6UdkiqLjo0Qw5zrabmU EscZL6ihfUzfzzodeZ1ZnL/7C6bpQ16/yj1/OXLZE7tSD+Bijdsf9PgBbl8VsetXdF32 FPfHme6avdYnKlOCofG130NsSP5725C6Iw7JKBgh0KR5kZvAvU0Fe7EEuCssmtlW5VuV GYZmRUw4XtOLkuR4HwdgIzOB8A+Hxduk1dOmsXfO2foah+qyzDXmyIfqR0crKPM+vX4a MyvuiRX57p+faQcVZHCYNruiD9P0y6lkyaZgZxFXCbdYXUFXOa11/q7wCydepcSLMPm5 JkEA== 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 k6-20020aa7d8c6000000b0052279c57c79si144697eds.341.2023.08.17.12.27.51; Thu, 17 Aug 2023 12:28:17 -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 S244013AbjHPKpK (ORCPT + 99 others); Wed, 16 Aug 2023 06:45:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51752 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244057AbjHPKpC (ORCPT ); Wed, 16 Aug 2023 06:45:02 -0400 Received: from laurent.telenet-ops.be (laurent.telenet-ops.be [IPv6:2a02:1800:110:4::f00:19]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3E592210E for ; Wed, 16 Aug 2023 03:44:43 -0700 (PDT) Received: from ramsan.of.borg ([IPv6:2a02:1810:ac12:ed40:5d0c:f209:12a7:4ce5]) by laurent.telenet-ops.be with bizsmtp id aAkg2A00E45ualL01AkgUv; Wed, 16 Aug 2023 12:44:41 +0200 Received: from rox.of.borg ([192.168.97.57]) by ramsan.of.borg with esmtp (Exim 4.95) (envelope-from ) id 1qWE0v-000orW-P8; Wed, 16 Aug 2023 12:44:40 +0200 Received: from geert by rox.of.borg with local (Exim 4.95) (envelope-from ) id 1qWDAx-00676k-1U; Wed, 16 Aug 2023 11:50:51 +0200 From: Geert Uytterhoeven To: Laurent Pinchart , Kieran Bingham , David Airlie , Daniel Vetter , Thomas Zimmermann , Magnus Damm Cc: dri-devel@lists.freedesktop.org, linux-renesas-soc@vger.kernel.org, linux-kernel@vger.kernel.org, Geert Uytterhoeven , Laurent Pinchart Subject: [PATCH v3 33/41] drm: renesas: shmobile: Turn vblank on/off when enabling/disabling CRTC Date: Wed, 16 Aug 2023 11:50:40 +0200 Message-Id: <3474fc386331eeb1e4b3122a8811f62adda812b4.1692178020.git.geert+renesas@glider.be> X-Mailer: git-send-email 2.34.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-1.6 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE, SPF_NONE autolearn=no 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 DRM core vblank handling mechanism requires drivers to forcefully turn vblank reporting off when disabling the CRTC, and to restore the vblank reporting status when enabling the CRTC. Implement this using the drm_crtc_vblank_{on,off}() helpers. Note that drm_crtc_vblank_off() must be called at startup to synchronize the state of the vblank core code with the hardware, which is initially disabled. This is performed at CRTC creation time, requiring vertical blank initialization to be moved before creating CRTCs. Signed-off-by: Geert Uytterhoeven Reviewed-by: Laurent Pinchart --- v3: - No changes, v2: - Add Reviewed-by. --- drivers/gpu/drm/renesas/shmobile/shmob_drm_crtc.c | 10 +++++++++- drivers/gpu/drm/renesas/shmobile/shmob_drm_drv.c | 12 ++++++------ 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/drivers/gpu/drm/renesas/shmobile/shmob_drm_crtc.c b/drivers/gpu/drm/renesas/shmobile/shmob_drm_crtc.c index 20adb9d2fa178250..ab42a4999a55c475 100644 --- a/drivers/gpu/drm/renesas/shmobile/shmob_drm_crtc.c +++ b/drivers/gpu/drm/renesas/shmobile/shmob_drm_crtc.c @@ -271,6 +271,9 @@ static void shmob_drm_crtc_start(struct shmob_drm_crtc *scrtc) shmob_drm_crtc_start_stop(scrtc, true); + /* Turn vertical blank interrupt reporting back on. */ + drm_crtc_vblank_on(crtc); + scrtc->started = true; } @@ -283,10 +286,12 @@ static void shmob_drm_crtc_stop(struct shmob_drm_crtc *scrtc) return; /* - * Wait for page flip completion before stopping the CRTC as userspace + * Disable vertical blank interrupt reporting. We first need to wait + * for page flip completion before stopping the CRTC as userspace * expects page flips to eventually complete. */ shmob_drm_crtc_wait_page_flip(scrtc); + drm_crtc_vblank_off(crtc); /* Stop the LCDC. */ shmob_drm_crtc_start_stop(scrtc, false); @@ -519,6 +524,9 @@ int shmob_drm_crtc_create(struct shmob_drm_device *sdev) drm_crtc_helper_add(crtc, &crtc_helper_funcs); + /* Start with vertical blank interrupt reporting disabled. */ + drm_crtc_vblank_off(crtc); + return 0; } diff --git a/drivers/gpu/drm/renesas/shmobile/shmob_drm_drv.c b/drivers/gpu/drm/renesas/shmobile/shmob_drm_drv.c index 44f12bfcb3ce575d..78f9650e3a61365f 100644 --- a/drivers/gpu/drm/renesas/shmobile/shmob_drm_drv.c +++ b/drivers/gpu/drm/renesas/shmobile/shmob_drm_drv.c @@ -216,17 +216,17 @@ static int shmob_drm_probe(struct platform_device *pdev) if (ret) return ret; - ret = shmob_drm_modeset_init(sdev); - if (ret < 0) - return dev_err_probe(&pdev->dev, ret, - "failed to initialize mode setting\n"); - ret = drm_vblank_init(ddev, 1); if (ret < 0) { dev_err(&pdev->dev, "failed to initialize vblank\n"); - goto err_modeset_cleanup; + return ret; } + ret = shmob_drm_modeset_init(sdev); + if (ret < 0) + return dev_err_probe(&pdev->dev, ret, + "failed to initialize mode setting\n"); + ret = platform_get_irq(pdev, 0); if (ret < 0) goto err_modeset_cleanup; -- 2.34.1