]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/panthor: disable async work during unplug
authorKetil Johnsen <ketil.johnsen@arm.com>
Wed, 29 Oct 2025 11:14:10 +0000 (12:14 +0100)
committerLiviu Dudau <liviu.dudau@arm.com>
Mon, 3 Nov 2025 14:25:21 +0000 (14:25 +0000)
A previous change, "drm/panthor: Fix UAF race between device unplug and
FW event processing", fixes a real issue where new work was unexpectedly
queued after cancellation. This was fixed by a disable instead.

Apply the same disable logic to other device level async work on device
unplug as a precaution.

Signed-off-by: Ketil Johnsen <ketil.johnsen@arm.com>
Reviewed-by: Liviu Dudau <liviu.dudau@arm.com>
Link: https://patch.msgid.link/20251029111412.924104-1-ketil.johnsen@arm.com
Signed-off-by: Liviu Dudau <liviu.dudau@arm.com>
drivers/gpu/drm/panthor/panthor_device.c
drivers/gpu/drm/panthor/panthor_fw.c
drivers/gpu/drm/panthor/panthor_sched.c

index f488b8dd62e8cab5883a4a865219b9bf541b1753..f3ae93153b6e8e3685b4e86da8ecf0d19cc6732a 100644 (file)
@@ -121,7 +121,7 @@ static void panthor_device_reset_cleanup(struct drm_device *ddev, void *data)
 {
        struct panthor_device *ptdev = container_of(ddev, struct panthor_device, base);
 
-       cancel_work_sync(&ptdev->reset.work);
+       disable_work_sync(&ptdev->reset.work);
        destroy_workqueue(ptdev->reset.wq);
 }
 
index 0d6c6bb1e0ea5f2bbf4a716656bc2421c864fd70..38d87ab92eda49bb8a9a6ba25c7d078ff4d1e5aa 100644 (file)
@@ -1164,7 +1164,7 @@ void panthor_fw_unplug(struct panthor_device *ptdev)
 {
        struct panthor_fw_section *section;
 
-       cancel_delayed_work_sync(&ptdev->fw->watchdog.ping_work);
+       disable_delayed_work_sync(&ptdev->fw->watchdog.ping_work);
 
        if (!IS_ENABLED(CONFIG_PM) || pm_runtime_active(ptdev->base.dev)) {
                /* Make sure the IRQ handler cannot be called after that point. */
index 3507e189082a247eb5a94fd67bc0c512fe7a718c..e74ca071159d2ca6957841645f1d5f60ae0b43c7 100644 (file)
@@ -3877,8 +3877,9 @@ void panthor_sched_unplug(struct panthor_device *ptdev)
 {
        struct panthor_scheduler *sched = ptdev->scheduler;
 
-       cancel_delayed_work_sync(&sched->tick_work);
+       disable_delayed_work_sync(&sched->tick_work);
        disable_work_sync(&sched->fw_events_work);
+       disable_work_sync(&sched->sync_upd_work);
 
        mutex_lock(&sched->lock);
        if (sched->pm.has_ref) {
@@ -3896,8 +3897,6 @@ static void panthor_sched_fini(struct drm_device *ddev, void *res)
        if (!sched || !sched->csg_slot_count)
                return;
 
-       cancel_delayed_work_sync(&sched->tick_work);
-
        if (sched->wq)
                destroy_workqueue(sched->wq);