Re: [PATCH 09/10] drm/tidss: IRQ code cleanup

From: Laurent Pinchart
Date: Wed Nov 01 2023 - 10:52:45 EST


Hi Tomi,

Thank you for the patch.

On Wed, Nov 01, 2023 at 11:17:46AM +0200, Tomi Valkeinen wrote:
> The IRQ setup code is overly complex. All we really need to do is
> initialize the related fields in struct tidss_device, and request the
> IRQ.
>
> We can drop all the HW accesses, as they are pointless: the driver will
> set the IRQs correctly when it needs any of the IRQs, and at probe time
> we have done a reset, so we know that all the IRQs are masked by default
> in the hardware.

Even for K2G ?

> Thus we can combine the tidss_irq_preinstall() and
> tidss_irq_postinstall() into the tidss_irq_install() function, drop the
> HW accesses, and drop the use of spinlock, as this is done at init time
> and there can be no races.
>
> We can also drop the HW access from the tidss_irq_uninstall(), as the
> driver will anyway disable and suspend the hardware at remove time.
>
> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@xxxxxxxxxxxxxxxx>
> ---
> drivers/gpu/drm/tidss/tidss_drv.c | 2 ++
> drivers/gpu/drm/tidss/tidss_irq.c | 54 ++++++---------------------------------
> 2 files changed, 10 insertions(+), 46 deletions(-)
>
> diff --git a/drivers/gpu/drm/tidss/tidss_drv.c b/drivers/gpu/drm/tidss/tidss_drv.c
> index 64914331715a..37693f30d98b 100644
> --- a/drivers/gpu/drm/tidss/tidss_drv.c
> +++ b/drivers/gpu/drm/tidss/tidss_drv.c
> @@ -138,6 +138,8 @@ static int tidss_probe(struct platform_device *pdev)
>
> platform_set_drvdata(pdev, tidss);
>
> + spin_lock_init(&tidss->wait_lock);
> +
> ret = dispc_init(tidss);
> if (ret) {
> dev_err(dev, "failed to initialize dispc: %d\n", ret);
> diff --git a/drivers/gpu/drm/tidss/tidss_irq.c b/drivers/gpu/drm/tidss/tidss_irq.c
> index 0c681c7600bc..604334ef526a 100644
> --- a/drivers/gpu/drm/tidss/tidss_irq.c
> +++ b/drivers/gpu/drm/tidss/tidss_irq.c
> @@ -93,33 +93,21 @@ void tidss_irq_resume(struct tidss_device *tidss)
> spin_unlock_irqrestore(&tidss->wait_lock, flags);
> }
>
> -static void tidss_irq_preinstall(struct drm_device *ddev)
> -{
> - struct tidss_device *tidss = to_tidss(ddev);
> -
> - spin_lock_init(&tidss->wait_lock);
> -
> - tidss_runtime_get(tidss);
> -
> - dispc_set_irqenable(tidss->dispc, 0);
> - dispc_read_and_clear_irqstatus(tidss->dispc);
> -
> - tidss_runtime_put(tidss);
> -}
> -
> -static void tidss_irq_postinstall(struct drm_device *ddev)
> +int tidss_irq_install(struct drm_device *ddev, unsigned int irq)
> {
> struct tidss_device *tidss = to_tidss(ddev);
> - unsigned long flags;
> - unsigned int i;
> + int ret;
>
> - tidss_runtime_get(tidss);
> + if (irq == IRQ_NOTCONNECTED)
> + return -ENOTCONN;
>
> - spin_lock_irqsave(&tidss->wait_lock, flags);
> + ret = request_irq(irq, tidss_irq_handler, 0, ddev->driver->name, ddev);
> + if (ret)
> + return ret;
>
> tidss->irq_mask = DSS_IRQ_DEVICE_OCP_ERR;
>
> - for (i = 0; i < tidss->num_crtcs; ++i) {
> + for (unsigned int i = 0; i < tidss->num_crtcs; ++i) {
> struct tidss_crtc *tcrtc = to_tidss_crtc(tidss->crtcs[i]);
>
> tidss->irq_mask |= DSS_IRQ_VP_SYNC_LOST(tcrtc->hw_videoport);
> @@ -127,28 +115,6 @@ static void tidss_irq_postinstall(struct drm_device *ddev)
> tidss->irq_mask |= DSS_IRQ_VP_FRAME_DONE(tcrtc->hw_videoport);
> }
>
> - tidss_irq_update(tidss);
> -
> - spin_unlock_irqrestore(&tidss->wait_lock, flags);
> -
> - tidss_runtime_put(tidss);
> -}
> -
> -int tidss_irq_install(struct drm_device *ddev, unsigned int irq)
> -{
> - int ret;
> -
> - if (irq == IRQ_NOTCONNECTED)
> - return -ENOTCONN;
> -
> - tidss_irq_preinstall(ddev);
> -
> - ret = request_irq(irq, tidss_irq_handler, 0, ddev->driver->name, ddev);
> - if (ret)
> - return ret;
> -
> - tidss_irq_postinstall(ddev);
> -
> return 0;
> }
>
> @@ -156,9 +122,5 @@ void tidss_irq_uninstall(struct drm_device *ddev)
> {
> struct tidss_device *tidss = to_tidss(ddev);
>
> - tidss_runtime_get(tidss);
> - dispc_set_irqenable(tidss->dispc, 0);
> - tidss_runtime_put(tidss);
> -
> free_irq(tidss->irq, ddev);
> }
>

--
Regards,

Laurent Pinchart