drm/lima: add mask irq callback to gp and pp
authorErico Nunes <nunes.erico@gmail.com>
Fri, 5 Apr 2024 15:29:49 +0000 (17:29 +0200)
committerQiang Yu <yuq825@gmail.com>
Mon, 15 Apr 2024 01:05:38 +0000 (09:05 +0800)
This is needed because we want to reset those devices in device-agnostic
code such as lima_sched.
In particular, masking irqs will be useful before a hard reset to
prevent race conditions.

Signed-off-by: Erico Nunes <nunes.erico@gmail.com>
Signed-off-by: Qiang Yu <yuq825@gmail.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240405152951.1531555-2-nunes.erico@gmail.com
drivers/gpu/drm/lima/lima_bcast.c
drivers/gpu/drm/lima/lima_bcast.h
drivers/gpu/drm/lima/lima_gp.c
drivers/gpu/drm/lima/lima_pp.c
drivers/gpu/drm/lima/lima_sched.h

index fbc43f243c54d23721837c0f50477c6bdd6a606a..6d000504e1a4ee111f11c41cbd55803448cb489b 100644 (file)
@@ -43,6 +43,18 @@ void lima_bcast_suspend(struct lima_ip *ip)
 
 }
 
+int lima_bcast_mask_irq(struct lima_ip *ip)
+{
+       bcast_write(LIMA_BCAST_BROADCAST_MASK, 0);
+       bcast_write(LIMA_BCAST_INTERRUPT_MASK, 0);
+       return 0;
+}
+
+int lima_bcast_reset(struct lima_ip *ip)
+{
+       return lima_bcast_hw_init(ip);
+}
+
 int lima_bcast_init(struct lima_ip *ip)
 {
        int i;
index 465ee587bceb2f22b3552f8bb7b01338a74990bf..cd08841e47879ccbbeeab54f68583a96ced4f664 100644 (file)
@@ -13,4 +13,7 @@ void lima_bcast_fini(struct lima_ip *ip);
 
 void lima_bcast_enable(struct lima_device *dev, int num_pp);
 
+int lima_bcast_mask_irq(struct lima_ip *ip);
+int lima_bcast_reset(struct lima_ip *ip);
+
 #endif
index 6b354e2fb61d43438becf1483ab71ac16bf8dbed..e15295071533b5387e450dd4d9ff96d34d71750b 100644 (file)
@@ -233,6 +233,13 @@ static void lima_gp_task_mmu_error(struct lima_sched_pipe *pipe)
        lima_sched_pipe_task_done(pipe);
 }
 
+static void lima_gp_task_mask_irq(struct lima_sched_pipe *pipe)
+{
+       struct lima_ip *ip = pipe->processor[0];
+
+       gp_write(LIMA_GP_INT_MASK, 0);
+}
+
 static int lima_gp_task_recover(struct lima_sched_pipe *pipe)
 {
        struct lima_ip *ip = pipe->processor[0];
@@ -365,6 +372,7 @@ int lima_gp_pipe_init(struct lima_device *dev)
        pipe->task_error = lima_gp_task_error;
        pipe->task_mmu_error = lima_gp_task_mmu_error;
        pipe->task_recover = lima_gp_task_recover;
+       pipe->task_mask_irq = lima_gp_task_mask_irq;
 
        return 0;
 }
index d0d2db0ef1ce8060e704d7d0ab2a6637f7750f4f..a4a2ffe6527c2cc59ea0246392340a8ec4a920c6 100644 (file)
@@ -429,6 +429,9 @@ static void lima_pp_task_error(struct lima_sched_pipe *pipe)
 
                lima_pp_hard_reset(ip);
        }
+
+       if (pipe->bcast_processor)
+               lima_bcast_reset(pipe->bcast_processor);
 }
 
 static void lima_pp_task_mmu_error(struct lima_sched_pipe *pipe)
@@ -437,6 +440,20 @@ static void lima_pp_task_mmu_error(struct lima_sched_pipe *pipe)
                lima_sched_pipe_task_done(pipe);
 }
 
+static void lima_pp_task_mask_irq(struct lima_sched_pipe *pipe)
+{
+       int i;
+
+       for (i = 0; i < pipe->num_processor; i++) {
+               struct lima_ip *ip = pipe->processor[i];
+
+               pp_write(LIMA_PP_INT_MASK, 0);
+       }
+
+       if (pipe->bcast_processor)
+               lima_bcast_mask_irq(pipe->bcast_processor);
+}
+
 static struct kmem_cache *lima_pp_task_slab;
 static int lima_pp_task_slab_refcnt;
 
@@ -468,6 +485,7 @@ int lima_pp_pipe_init(struct lima_device *dev)
        pipe->task_fini = lima_pp_task_fini;
        pipe->task_error = lima_pp_task_error;
        pipe->task_mmu_error = lima_pp_task_mmu_error;
+       pipe->task_mask_irq = lima_pp_task_mask_irq;
 
        return 0;
 }
index 6bd4f3b70109133d494d3f5f9cb1019ab6e207f8..85b23ba901d53ee52fa73b67fa8e7953bb08deaa 100644 (file)
@@ -80,6 +80,7 @@ struct lima_sched_pipe {
        void (*task_error)(struct lima_sched_pipe *pipe);
        void (*task_mmu_error)(struct lima_sched_pipe *pipe);
        int (*task_recover)(struct lima_sched_pipe *pipe);
+       void (*task_mask_irq)(struct lima_sched_pipe *pipe);
 
        struct work_struct recover_work;
 };