From: Boris Brezillon Date: Fri, 31 Oct 2025 16:03:18 +0000 (+0100) Subject: drm/panthor: Fix group_free_queue() for partially initialized queues X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=94a6d20feadbbe24e8a7b1c56394789ea5358fcc;p=thirdparty%2Fkernel%2Flinux.git drm/panthor: Fix group_free_queue() for partially initialized queues group_free_queue() can be called on a partially initialized queue object if something fails in group_create_queue(). Make sure we don't call drm_sched_entity_destroy() on an entity that hasn't been initialized. Fixes: 7d9c3442b02a ("drm/panthor: Defer scheduler entitiy destruction to queue release") Reviewed-by: Adrián Larumbe Reviewed-by: Liviu Dudau Signed-off-by: Boris Brezillon Link: https://patch.msgid.link/20251031160318.832427-2-boris.brezillon@collabora.com Signed-off-by: Liviu Dudau --- diff --git a/drivers/gpu/drm/panthor/panthor_sched.c b/drivers/gpu/drm/panthor/panthor_sched.c index 1ce44d5a839d2..c9c6bfe47b76e 100644 --- a/drivers/gpu/drm/panthor/panthor_sched.c +++ b/drivers/gpu/drm/panthor/panthor_sched.c @@ -899,7 +899,8 @@ static void group_free_queue(struct panthor_group *group, struct panthor_queue * if (IS_ERR_OR_NULL(queue)) return; - drm_sched_entity_destroy(&queue->entity); + if (queue->entity.fence_context) + drm_sched_entity_destroy(&queue->entity); if (queue->scheduler.ops) drm_sched_fini(&queue->scheduler);