drm/xe/sa: Always call drm_suballoc_manager_fini()
authorMichal Wajdeczko <michal.wajdeczko@intel.com>
Fri, 20 Dec 2024 19:41:54 +0000 (20:41 +0100)
committerMichal Wajdeczko <michal.wajdeczko@intel.com>
Sat, 18 Jan 2025 23:11:56 +0000 (00:11 +0100)
After successful call to drm_suballoc_manager_init() we should
make sure to call drm_suballoc_manager_fini() as it may include
some cleanup code even if we didn't start using it for real.

As we can abort init() early due to kvzalloc() failure, we should
either explicitly call drm_suballoc_manager_fini() or, even better,
postpone drm_suballoc_manager_init() once we finish all other
preparation steps, so we can rely on fini() that will do cleanup.

Signed-off-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Cc: Matthew Brost <matthew.brost@intel.com>
Reviewed-by: Matthew Brost <matthew.brost@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20241220194205.995-2-michal.wajdeczko@intel.com
drivers/gpu/drm/xe/xe_sa.c

index e055bed7ae55553e85533fdc80caecd593d52201..4e7aba445ebc8a249d77f6be82053fca2ce85f5a 100644 (file)
@@ -57,8 +57,6 @@ struct xe_sa_manager *xe_sa_bo_manager_init(struct xe_tile *tile, u32 size, u32
        }
        sa_manager->bo = bo;
        sa_manager->is_iomem = bo->vmap.is_iomem;
-
-       drm_suballoc_manager_init(&sa_manager->base, managed_size, align);
        sa_manager->gpu_addr = xe_bo_ggtt_addr(bo);
 
        if (bo->vmap.is_iomem) {
@@ -72,6 +70,7 @@ struct xe_sa_manager *xe_sa_bo_manager_init(struct xe_tile *tile, u32 size, u32
                memset(sa_manager->cpu_ptr, 0, bo->ttm.base.size);
        }
 
+       drm_suballoc_manager_init(&sa_manager->base, managed_size, align);
        ret = drmm_add_action_or_reset(&xe->drm, xe_sa_bo_manager_fini,
                                       sa_manager);
        if (ret)