From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-14.5 required=3.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER, INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 55BBAC4338F for ; Tue, 3 Aug 2021 15:02:23 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 2433E60EBB for ; Tue, 3 Aug 2021 15:02:23 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.4.1 mail.kernel.org 2433E60EBB Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ravnborg.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=dPNPMW1Zvz6KFlwHMKfr1i48tpvYxJRsm9g8IWWgwkY=; b=zfBEF5FxrMCraz tB4r/wE1uooUNe27dU6h6JP9ztHWUPIQzD8RBOX+07ZHVJbEvumkiGE7lNK0SslByfTzLZ9BaHVaq FWg5LHyU+wMvEX3PSrzp1amqWAVw26bMO9wipEhZOOX88PNUXagzzqt4BEyUxDDLMU2pqBpW0AV5/ 1uXlm4UznLRmzpm65lrCalGMmcCoKHN2EfKbc1Hamf1Sh17NObqSf+Gj4o9u21n1ESzAcmqz+/vZ8 cz2s/64Du5ho745vGlnbI31jf8pPWvvK35FPPfy+J9BDFMPlAPCjBRlhKesyTMWB7X+CDMkSXtF6G BTmSH+cwv9XRWzUM7avg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1mAvu8-003Jgi-CS; Tue, 03 Aug 2021 15:00:28 +0000 Received: from mx2.smtp.larsendata.com ([91.221.196.228]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1mAvu0-003JXp-QC for linux-arm-kernel@lists.infradead.org; Tue, 03 Aug 2021 15:00:22 +0000 Received: from mail01.mxhotel.dk (mail01.mxhotel.dk [91.221.196.236]) by mx2.smtp.larsendata.com (Halon) with ESMTPS id 8b9d7efa-f46b-11eb-8d1a-0050568cd888; Tue, 03 Aug 2021 15:00:30 +0000 (UTC) Received: from ravnborg.org (80-162-45-141-cable.dk.customer.tdc.net [80.162.45.141]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: sam@ravnborg.org) by mail01.mxhotel.dk (Postfix) with ESMTPSA id 05278194B8B; Tue, 3 Aug 2021 17:00:36 +0200 (CEST) Date: Tue, 3 Aug 2021 17:00:08 +0200 X-Report-Abuse-To: abuse@mxhotel.dk From: Sam Ravnborg To: Thomas Zimmermann Subject: Re: [PATCH v2 11/14] drm/tilcdc: Convert to Linux IRQ interfaces Message-ID: References: <20210803090704.32152-1-tzimmermann@suse.de> <20210803090704.32152-12-tzimmermann@suse.de> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20210803090704.32152-12-tzimmermann@suse.de> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20210803_080021_179970_FB189AC6 X-CRM114-Status: GOOD ( 31.06 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: airlied@linux.ie, tomi.valkeinen@ideasonboard.com, liviu.dudau@arm.com, stefan@agner.ch, amd-gfx@lists.freedesktop.org, anitha.chrisanthus@intel.com, Dan.Sneddon@microchip.com, patrik.r.jakobsson@gmail.com, linux-arm-msm@vger.kernel.org, freedreno@lists.freedesktop.org, daniel@ffwll.ch, edmund.j.dea@intel.com, s.hauer@pengutronix.de, alison.wang@nxp.com, maarten.lankhorst@linux.intel.com, mripard@kernel.org, dri-devel@lists.freedesktop.org, sean@poorly.run, linux-arm-kernel@lists.infradead.org, tomba@kernel.org, bbrezillon@kernel.org, jyri.sarha@iki.fi, christian.koenig@amd.com, robdclark@gmail.com, kernel@pengutronix.de, alexander.deucher@amd.com, shawnguo@kernel.org, brian.starkey@arm.com Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Thomas, On Tue, Aug 03, 2021 at 11:07:01AM +0200, Thomas Zimmermann wrote: > Drop the DRM IRQ midlayer in favor of Linux IRQ interfaces. DRM's > IRQ helpers are mostly useful for UMS drivers. Modern KMS drivers > don't benefit from using it. > > DRM IRQ callbacks are now being called directly or inlined. > > Calls to platform_get_irq() can fail with a negative errno code. > Abort initialization in this case. The DRM IRQ midlayer does not > handle this case correctly. I cannot see why the irq_enabled flag is needed here, and the changelog do not help me. What do I miss? Sam > > Signed-off-by: Thomas Zimmermann > --- > drivers/gpu/drm/tilcdc/tilcdc_drv.c | 51 ++++++++++++++++++++++------- > drivers/gpu/drm/tilcdc/tilcdc_drv.h | 3 ++ > 2 files changed, 43 insertions(+), 11 deletions(-) > > diff --git a/drivers/gpu/drm/tilcdc/tilcdc_drv.c b/drivers/gpu/drm/tilcdc/tilcdc_drv.c > index f1d3a9f919fd..6b03f89a98d4 100644 > --- a/drivers/gpu/drm/tilcdc/tilcdc_drv.c > +++ b/drivers/gpu/drm/tilcdc/tilcdc_drv.c > @@ -20,7 +20,6 @@ > #include > #include > #include > -#include > #include > #include > #include > @@ -124,6 +123,39 @@ static int cpufreq_transition(struct notifier_block *nb, > } > #endif > > +static irqreturn_t tilcdc_irq(int irq, void *arg) > +{ > + struct drm_device *dev = arg; > + struct tilcdc_drm_private *priv = dev->dev_private; > + > + return tilcdc_crtc_irq(priv->crtc); > +} > + > +static int tilcdc_irq_install(struct drm_device *dev, unsigned int irq) > +{ > + struct tilcdc_drm_private *priv = dev->dev_private; > + int ret; > + > + ret = request_irq(irq, tilcdc_irq, 0, dev->driver->name, dev); > + if (ret) > + return ret; > + > + priv->irq_enabled = false; > + > + return 0; > +} > + > +static void tilcdc_irq_uninstall(struct drm_device *dev) > +{ > + struct tilcdc_drm_private *priv = dev->dev_private; > + > + if (!priv->irq_enabled) > + return; > + > + free_irq(priv->irq, dev); > + priv->irq_enabled = false; > +} > + > /* > * DRM operations: > */ > @@ -145,7 +177,7 @@ static void tilcdc_fini(struct drm_device *dev) > drm_dev_unregister(dev); > > drm_kms_helper_poll_fini(dev); > - drm_irq_uninstall(dev); > + tilcdc_irq_uninstall(dev); > drm_mode_config_cleanup(dev); > > if (priv->clk) > @@ -336,7 +368,12 @@ static int tilcdc_init(const struct drm_driver *ddrv, struct device *dev) > goto init_failed; > } > > - ret = drm_irq_install(ddev, platform_get_irq(pdev, 0)); > + ret = platform_get_irq(pdev, 0); > + if (ret < 0) > + goto init_failed; > + priv->irq = ret; > + > + ret = tilcdc_irq_install(ddev, priv->irq); > if (ret < 0) { > dev_err(dev, "failed to install IRQ handler\n"); > goto init_failed; > @@ -360,13 +397,6 @@ static int tilcdc_init(const struct drm_driver *ddrv, struct device *dev) > return ret; > } > > -static irqreturn_t tilcdc_irq(int irq, void *arg) > -{ > - struct drm_device *dev = arg; > - struct tilcdc_drm_private *priv = dev->dev_private; > - return tilcdc_crtc_irq(priv->crtc); > -} > - > #if defined(CONFIG_DEBUG_FS) > static const struct { > const char *name; > @@ -454,7 +484,6 @@ DEFINE_DRM_GEM_CMA_FOPS(fops); > > static const struct drm_driver tilcdc_driver = { > .driver_features = DRIVER_GEM | DRIVER_MODESET | DRIVER_ATOMIC, > - .irq_handler = tilcdc_irq, > DRM_GEM_CMA_DRIVER_OPS, > #ifdef CONFIG_DEBUG_FS > .debugfs_init = tilcdc_debugfs_init, > diff --git a/drivers/gpu/drm/tilcdc/tilcdc_drv.h b/drivers/gpu/drm/tilcdc/tilcdc_drv.h > index d29806ca8817..b818448c83f6 100644 > --- a/drivers/gpu/drm/tilcdc/tilcdc_drv.h > +++ b/drivers/gpu/drm/tilcdc/tilcdc_drv.h > @@ -46,6 +46,8 @@ struct tilcdc_drm_private { > struct clk *clk; /* functional clock */ > int rev; /* IP revision */ > > + unsigned int irq; > + > /* don't attempt resolutions w/ higher W * H * Hz: */ > uint32_t max_bandwidth; > /* > @@ -82,6 +84,7 @@ struct tilcdc_drm_private { > > bool is_registered; > bool is_componentized; > + bool irq_enabled; > }; > > /* Sub-module for display. Since we don't know at compile time what panels > -- > 2.32.0 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel