Received: by 2002:a05:7412:b795:b0:e2:908c:2ebd with SMTP id iv21csp221189rdb; Thu, 2 Nov 2023 01:25:00 -0700 (PDT) X-Google-Smtp-Source: AGHT+IGtqtP06lpEEmK4H1/utV6reh9poLaxKiUREbqEJ3Wc8L3hXJUALt5Tcpq157hvl5+sf9KU X-Received: by 2002:a25:b53:0:b0:d9a:ccdf:3873 with SMTP id 80-20020a250b53000000b00d9accdf3873mr16223716ybl.48.1698913500169; Thu, 02 Nov 2023 01:25:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698913500; cv=none; d=google.com; s=arc-20160816; b=Gipjriz2Dr/MuMrXa82v2WPIFlJ1HORfxBcgvbXyB/zg4FXWFfXn/7pvGsNfeAye8D g0zPITHh0G2YV8a4b0hlztdvfDI3RQ7/uwZcR8aRvDlZo94HpZDZLsAAvWMItzflRzfl HBoSWN+Wiz9ubXqU0cS3HNvchbQxxyCLQiWgCfeyijNYdJf+BSfs1XErjX6I1Z6CGW6N y+0rTYxR4II36l5EJtORYHIo40VlilWxL4krAKPjBySENJPD4iJxPqGAWWv1NJfx8TQ+ vZbvD439MVJzF3YNPeE8A58+EdmUWXcVIMH5VzvlqjUMQY6174Zf2zX2JKmlvjGlMTUj xLhA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:autocrypt :from:references:cc:to:content-language:subject:user-agent :mime-version:date:message-id:dkim-signature; bh=vY8RxPnIGnP/rJjKcubOT1RYQvDe47RO7cJyTifgF+Q=; fh=OsSgmFzadAUn0DjzfPlpZpO0oO19ZvwhLQFcltgMC98=; b=zES9eqRg2f++fJHLRWTxOQ9QrNrOfT9oXeFMvww21zLqWYCvLs0NQt9S38cZIaWYYa bMdF/PeScRKZpesBc1Oa0tYQsWuVBQHkUrvlXYo/F/mzt8DaeU835Y0XfBC43YIBsE55 Pny1cMuLVtfoGX/8jLlHyo6uaJ5Ha+AhnejYSg4B0Z45pCWoD+GBA4oQeppzX5840PSh F21KvwCpOHBcsjnQXNdY5P4zNzhUbAOXaRNlAzUnniAQbbF31mcdpeWObu2gDz9wH6pS GPhSKuki+1kWEHLTUPMSIXyJiRILyuY//+o9KSBoI68dGDi7Q3cBFB+66vTaTCfq9OJV fz7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=HUpwC3jP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lipwig.vger.email (lipwig.vger.email. [2620:137:e000::3:3]) by mx.google.com with ESMTPS id e6-20020aa79806000000b006c339f9f3a1si276329pfl.240.2023.11.02.01.24.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Nov 2023 01:25:00 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) client-ip=2620:137:e000::3:3; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=HUpwC3jP; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:3 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by lipwig.vger.email (Postfix) with ESMTP id 59F71810EC15; Thu, 2 Nov 2023 01:24:45 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at lipwig.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S234637AbjKBIYL (ORCPT + 99 others); Thu, 2 Nov 2023 04:24:11 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58722 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229526AbjKBIYK (ORCPT ); Thu, 2 Nov 2023 04:24:10 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7844D112 for ; Thu, 2 Nov 2023 01:24:04 -0700 (PDT) Received: from [192.168.88.20] (91-158-149-209.elisa-laajakaista.fi [91.158.149.209]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 1FF117E2; Thu, 2 Nov 2023 09:23:44 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1698913424; bh=dY5VRG4sVx51nuZ109mj20vCcQCtdywyr1QIsou8CtI=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=HUpwC3jPIFc0KkExQUPR9vaqPIus1tFugm5UEOQV8Cju9QQ/IMqBTQWNJW2YchODt O1UrFQcWRNLsmForvO44X4VNGhoeojjYkNp5ROKhhK85PFtitsvUX2qdTRFvwwpTC9 fcd6aR39OMhO5gs1Fo+XI2+h5/v7QP32c5IJbTeo= Message-ID: <4fc5c307-082d-4c72-90c8-7bd7efcd2184@ideasonboard.com> Date: Thu, 2 Nov 2023 10:23:58 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH 10/10] drm/tidss: Fix atomic_flush check Content-Language: en-US To: Laurent Pinchart Cc: Aradhya Bhatia , Devarsh Thakkar , Jyri Sarha , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20231101-tidss-probe-v1-0-45149e0f9415@ideasonboard.com> <20231101-tidss-probe-v1-10-45149e0f9415@ideasonboard.com> <20231101145658.GZ12764@pendragon.ideasonboard.com> From: Tomi Valkeinen Autocrypt: addr=tomi.valkeinen@ideasonboard.com; keydata= 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 In-Reply-To: <20231101145658.GZ12764@pendragon.ideasonboard.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lipwig.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 (lipwig.vger.email [0.0.0.0]); Thu, 02 Nov 2023 01:24:45 -0700 (PDT) On 01/11/2023 16:56, Laurent Pinchart wrote: > Hi Tomi, > > Thank you for the patch. > > On Wed, Nov 01, 2023 at 11:17:47AM +0200, Tomi Valkeinen wrote: >> tidss_crtc_atomic_flush() checks if the crtc is enabled, and if not, >> returns immediately as there's no reason to do any register changes. >> >> However, the code checks for 'crtc->state->enable', which does not >> reflect the actual HW state. We should instead look at the >> 'crtc->state->active' flag. >> >> This causes the tidss_crtc_atomic_flush() to proceed with the flush even >> if the active state is false, which then causes us to hit the >> WARN_ON(!crtc->state->event) check. >> >> Fix this by checking the active flag, and while at it, fix the related >> debug print which had "active" and "needs modeset" wrong way. >> >> Signed-off-by: Tomi Valkeinen >> --- >> drivers/gpu/drm/tidss/tidss_crtc.c | 9 ++++----- >> 1 file changed, 4 insertions(+), 5 deletions(-) >> >> diff --git a/drivers/gpu/drm/tidss/tidss_crtc.c b/drivers/gpu/drm/tidss/tidss_crtc.c >> index 5e5e466f35d1..4c7009a5d643 100644 >> --- a/drivers/gpu/drm/tidss/tidss_crtc.c >> +++ b/drivers/gpu/drm/tidss/tidss_crtc.c >> @@ -169,13 +169,12 @@ static void tidss_crtc_atomic_flush(struct drm_crtc *crtc, >> struct tidss_device *tidss = to_tidss(ddev); >> unsigned long flags; >> >> - dev_dbg(ddev->dev, >> - "%s: %s enabled %d, needs modeset %d, event %p\n", __func__, >> - crtc->name, drm_atomic_crtc_needs_modeset(crtc->state), >> - crtc->state->enable, crtc->state->event); >> + dev_dbg(ddev->dev, "%s: %s active %d, needs modeset %d, event %p\n", >> + __func__, crtc->name, crtc->state->active, >> + drm_atomic_crtc_needs_modeset(crtc->state), crtc->state->event); > > While at it, how about this ? Why not. The active part won't be needed if we use DRM_PLANE_COMMIT_ACTIVE_ONLY, though. > dev_dbg(ddev->dev, "%s: %s is %sactive, %s modeset, event %p\n", > __func__, crtc->name, crtc->state->active ? "" : "not ", > drm_atomic_crtc_needs_modeset(crtc->state) ? "needs", "doesn't need", > crtc->state->event); > >> >> /* There is nothing to do if CRTC is not going to be enabled. */ >> - if (!crtc->state->enable) >> + if (!crtc->state->active) > > I think the drm_atomic_helper_commit_planes() helper will handle this if > you pass it the DRM_PLANE_COMMIT_ACTIVE_ONLY flag. I considered it, but it does a bit more, as it also affects the plane updates. We specifically did not use DRM_PLANE_COMMIT_ACTIVE_ONLY as it didn't work with DSS. That said, I can't figure out what was the issue. It's possible the issue was only on the older DSS HW, with omapdrm (tidss code was originally somewhat based on omapdrm). I'm pretty sure the issue was related to multi-display systems and the plane updates there. But I don't have any multi-display board which uses tidss. So, I'll keep this patch, but add another on top, which uses DRM_PLANE_COMMIT_ACTIVE_ONLY. Then it'll be easy to revert the DRM_PLANE_COMMIT_ACTIVE_ONLY one if needed, while still keeping this fix. Tomi