Received: by 2002:a05:7412:f589:b0:e2:908c:2ebd with SMTP id eh9csp954999rdb; Wed, 1 Nov 2023 07:31:30 -0700 (PDT) X-Google-Smtp-Source: AGHT+IEWVzNbObjyqlDNJvw0RHMY4OZRQlXVbPpfZArFwNvsEwxJBO2kxInT5jn8ikZ+naTHlDpC X-Received: by 2002:a17:903:244e:b0:1cc:70e4:28d7 with SMTP id l14-20020a170903244e00b001cc70e428d7mr4175901pls.10.1698849089918; Wed, 01 Nov 2023 07:31:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698849089; cv=none; d=google.com; s=arc-20160816; b=RXXdfhycWbrLFFKmICWDUwGusCOLFgquq+mRvrVGl0tvCxKtCPWoxz/Jgo8OdK112O kherm4Mfb7Twx2jiENYbdesJGbAvpUIjpnGizo67X01vND0GHL5ZUEZ6jO+CIwp4mFsI 9XhqDEdHfjl3bO/N/NDaoJS8Ug0Oj6wyOIVa6yQEM1nGFRhD9OI4Q5ZyuscyyF0qrmgu pLxtC4IdzaEv/Of+WOwNmjVO11wXIea/fBZoChlIj3ywLIqPHocVjZ6SbRgL9gHJvhRC DGUfQxkCMz2BJT+ZWdTyooIAlC5DHzHphajdw2+E/qj3MZrv0UWj6fHjZT0izxxYBom7 Ox2Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=h/qdchTytxv71kzFtSVY2PUgLTt3C4NlxuEmJJzgQd0=; fh=5C3CAkIfBsG8EK8jEaBmpiwV3a9azH+DT0pG9NOmIu4=; b=QKC/kfKvGruDxo4aUXgZKUULIJYw1Vm0QK1Jqvq3LSfBEKqVbF4iquY+BT+OyJcJAs EvJopzcu1SuJ0WVpaA4vt7KABXWV41ktLQrEZUJqaps38PV5CDOpFLWPM8wZ5h9qB9kd 03QSHzMeSqv8kH+QRziOCfo6+Z2MCKSureL7Mg1LWAihJ5WMzjqRiP9jIQ10i9SBk+GT KO4/esIrhh/Cr1Lju+owGMZMRCuKM+BjbNJFr39CsM4j3LigAaHdeg12AJlsnmI2qr0Q xKDOAXQdugdgrqCpKohh/FIdn9FxpLTLnfQhMvzwpcQXOHK4rvF26uiS5JzcpsP5InBg rKBw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b="BY7/rBVV"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from groat.vger.email (groat.vger.email. [2620:137:e000::3:5]) by mx.google.com with ESMTPS id i15-20020a170902c94f00b001c9c9e6371fsi3238530pla.527.2023.11.01.07.31.29 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 01 Nov 2023 07:31:29 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) client-ip=2620:137:e000::3:5; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b="BY7/rBVV"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 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 groat.vger.email (Postfix) with ESMTP id 81181808494B; Wed, 1 Nov 2023 07:31:17 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344313AbjKAObC (ORCPT + 99 others); Wed, 1 Nov 2023 10:31:02 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:57294 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233968AbjKAObA (ORCPT ); Wed, 1 Nov 2023 10:31:00 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0725710F for ; Wed, 1 Nov 2023 07:30:55 -0700 (PDT) Received: from pendragon.ideasonboard.com (213-243-189-158.bb.dnainternet.fi [213.243.189.158]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 515308D; Wed, 1 Nov 2023 15:30:36 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1698849036; bh=5YItRrUaGKRTGgloO8CSQlNybPFcehQUacBIcp7TFQo=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=BY7/rBVV1WFwrTtf9vUXoH1UVOHSVGHJ7DfBOi29HZc8FJlCDQoKrtISkCZvR82NN 7Y0uvzumAePtTS15gmrDGnV+DAeQz3LE2ti+Tn1wZKCp4uLkpwfKf8ItBPV1hOIYQ2 7B4mf2NRF7V/bDqC2CsbQf++NTst6E/rZMT5rO2A= Date: Wed, 1 Nov 2023 16:30:59 +0200 From: Laurent Pinchart To: Tomi Valkeinen 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 Subject: Re: [PATCH 07/10] drm/tidss: Fix dss reset Message-ID: <20231101143059.GW12764@pendragon.ideasonboard.com> References: <20231101-tidss-probe-v1-0-45149e0f9415@ideasonboard.com> <20231101-tidss-probe-v1-7-45149e0f9415@ideasonboard.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20231101-tidss-probe-v1-7-45149e0f9415@ideasonboard.com> 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 groat.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 (groat.vger.email [0.0.0.0]); Wed, 01 Nov 2023 07:31:17 -0700 (PDT) Hi Tomi, Thank you for the patch. On Wed, Nov 01, 2023 at 11:17:44AM +0200, Tomi Valkeinen wrote: > The probe function calls dispc_softreset() before runtime PM is enabled > and without enabling any of the DSS clocks. This happens to work by > luck, and we need to make sure the DSS HW is active and the fclk is > enabled. > > To fix the above, add a new function, dispc_init_hw(), which does: > > - pm_runtime_set_active() > - clk_prepare_enable(fclk) > - dispc_softreset(). > > This ensures that the reset can be successfully accomplished. > > Note that we use pm_runtime_set_active(), not the normal > pm_runtime_get(). The reason for this is that at this point we haven't > enabled the runtime PM yet and also we don't want the normal resume > callback to be called: the dispc resume callback does some initial HW > setup, and it expects that the HW was off (no video ports are > streaming). If the bootloader has enabled the DSS and has set up a > boot time splash-screen, the DSS would be enabled and streaming which > might lead to issues with the normal resume callback. I think the right way to do this would be, in probe(), to - power on the device - enable runtime PM, masking the device as active - at end of probe, calling pm_runtime_put_autosuspend() Please also see my review of patch 02/10. > Signed-off-by: Tomi Valkeinen > --- > drivers/gpu/drm/tidss/tidss_dispc.c | 45 ++++++++++++++++++++++++++++++++++++- > 1 file changed, 44 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/tidss/tidss_dispc.c b/drivers/gpu/drm/tidss/tidss_dispc.c > index f204a0701e9f..13db062892e3 100644 > --- a/drivers/gpu/drm/tidss/tidss_dispc.c > +++ b/drivers/gpu/drm/tidss/tidss_dispc.c > @@ -2724,6 +2724,49 @@ static int dispc_softreset(struct dispc_device *dispc) > return 0; > } > > +static int dispc_init_hw(struct dispc_device *dispc) > +{ > + struct device *dev = dispc->dev; > + int ret; > + > + ret = pm_runtime_set_active(dev); > + if (ret) { > + dev_err(dev, "Failed to set DSS PM to active\n"); > + return ret; > + } > + > + ret = clk_prepare_enable(dispc->fclk); > + if (ret) { > + dev_err(dev, "Failed to enable DSS fclk\n"); > + goto err_runtime_suspend; > + } > + > + ret = dispc_softreset(dispc); > + if (ret) > + goto err_clk_disable; > + > + clk_disable_unprepare(dispc->fclk); > + ret = pm_runtime_set_suspended(dev); > + if (ret) { > + dev_err(dev, "Failed to set DSS PM to suspended\n"); > + return ret; > + } > + > + return 0; > + > +err_clk_disable: > + clk_disable_unprepare(dispc->fclk); > + > +err_runtime_suspend: > + ret = pm_runtime_set_suspended(dev); > + if (ret) { > + dev_err(dev, "Failed to set DSS PM to suspended\n"); > + return ret; > + } > + > + return ret; > +} > + > int dispc_init(struct tidss_device *tidss) > { > struct device *dev = tidss->dev; > @@ -2835,7 +2878,7 @@ int dispc_init(struct tidss_device *tidss) > > tidss->dispc = dispc; > > - r = dispc_softreset(dispc); > + r = dispc_init_hw(dispc); > if (r) > return r; > -- Regards, Laurent Pinchart