Switch from request_irq()/free_irq() to the device-managed alternative
devm_request_irq(), letting device-managed resource cleanup handle IRQ
teardown automatically.

While here, inline vc4_irq_prepare() into vc4_irq_install() since it's
the only caller.

Signed-off-by: Maíra Canal <[email protected]>
---
 drivers/gpu/drm/vc4/vc4_irq.c | 31 +++++++++++--------------------
 1 file changed, 11 insertions(+), 20 deletions(-)

diff --git a/drivers/gpu/drm/vc4/vc4_irq.c b/drivers/gpu/drm/vc4/vc4_irq.c
index 
aa6cccf58917a51549099ede4b3272e9627ff39c..36d061e6ab8f3f4b9e199cd6810a0c39e00be573
 100644
--- a/drivers/gpu/drm/vc4/vc4_irq.c
+++ b/drivers/gpu/drm/vc4/vc4_irq.c
@@ -47,7 +47,6 @@
 
 #include <linux/platform_device.h>
 
-#include <drm/drm_drv.h>
 #include <drm/drm_print.h>
 
 #include "vc4_drv.h"
@@ -163,22 +162,6 @@ vc4_irq(int irq, void *arg)
        return status;
 }
 
-static void
-vc4_irq_prepare(struct drm_device *dev)
-{
-       struct vc4_dev *vc4 = to_vc4_dev(dev);
-
-       if (!vc4->v3d)
-               return;
-
-       INIT_WORK(&vc4->overflow_mem_work, vc4_overflow_mem_work);
-
-       /* Clear any pending interrupts someone might have left around
-        * for us.
-        */
-       V3D_WRITE(V3D_INTCTL, V3D_DRIVER_IRQS);
-}
-
 void
 vc4_irq_enable(struct drm_device *dev)
 {
@@ -227,12 +210,21 @@ int vc4_irq_install(struct drm_device *dev, int irq)
        if (WARN_ON_ONCE(vc4->gen > VC4_GEN_4))
                return -ENODEV;
 
+       if (!vc4->v3d)
+               return -ENODEV;
+
        if (irq == IRQ_NOTCONNECTED)
                return -ENOTCONN;
 
-       vc4_irq_prepare(dev);
+       INIT_WORK(&vc4->overflow_mem_work, vc4_overflow_mem_work);
 
-       ret = request_irq(irq, vc4_irq, 0, dev->driver->name, dev);
+       /* Clear any pending interrupts someone might have left around
+        * for us.
+        */
+       V3D_WRITE(V3D_INTCTL, V3D_DRIVER_IRQS);
+
+       ret = devm_request_irq(dev->dev, irq, vc4_irq, 0,
+                              dev_name(dev->dev), dev);
        if (ret)
                return ret;
 
@@ -249,7 +241,6 @@ void vc4_irq_uninstall(struct drm_device *dev)
                return;
 
        vc4_irq_disable(dev);
-       free_irq(vc4->irq, dev);
 }
 
 /** Reinitializes interrupt registers when a GPU reset is performed. */

-- 
2.52.0

Reply via email to