drm/ttm: WARN_ON non-empty lru when disabling a resource manager
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Fri, 11 Dec 2020 16:29:42 +0000 (17:29 +0100)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Mon, 18 Jan 2021 13:15:20 +0000 (14:15 +0100)
ttm_resource_manager->use_type is only used for runtime changes by
vmwgfx. I think ideally we'd push this functionality into drivers -
ttm itself does not provide any locking to guarantee this is safe, so
the only way this can work at runtime is if the driver does provide
additional guarantees. vwmgfx does that through the
vmw_private->reservation_sem. Therefore supporting this feature in
shared code feels a bit misplaced.

As a first step add a WARN_ON to make sure the resource manager is
empty. This is just to make sure I actually understand correctly what
vmwgfx is doing, and to make sure an eventual subsequent refactor
doesn't break anything.

This check should also be useful for other drivers, to make sure they
haven't leaked anything.

Reviewed-by: Roland Scheidegger <sroland@vmware.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Cc: Christian Koenig <christian.koenig@amd.com>
Cc: Huang Rui <ray.huang@amd.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20201211162942.3399050-3-daniel.vetter@ffwll.ch
include/drm/ttm/ttm_resource.h

index ad6da99770e91b3480aecc6dd854293c10bc309e..da0ed7e8c9155bdce58d25c95aaadc19861d1c25 100644 (file)
@@ -190,6 +190,10 @@ struct ttm_resource {
 static inline void
 ttm_resource_manager_set_used(struct ttm_resource_manager *man, bool used)
 {
+       int i;
+
+       for (i = 0; i < TTM_MAX_BO_PRIORITY; i++)
+               WARN_ON(!list_empty(&man->lru[i]));
        man->use_type = used;
 }