summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJan Vesely <jan.vesely@rutgers.edu>2018-05-08 01:39:04 -0400
committerJuan A. Suarez Romero <jasuarez@igalia.com>2018-05-15 11:14:49 +0200
commit876c7c7006eb13b91051bd5555859e5befba3e29 (patch)
tree57174a160a1a57cee59150757e3ae99bfdcde0af
parentd2632fc7658728dfa8b06db6c9aa54239d5bb544 (diff)
winsys/radeon: Destroy fd_hash table when the last winsys is removed.
Fixes memory leak on module unload. v2: Use util_hash_table helper function CC: <mesa-stable@lists.freedesktop.org> Reviewed-by: Marek Olšák <marek.olsak@amd.com> Signed-off-by: Jan Vesely <jan.vesely@rutgers.edu> (cherry picked from commit 45dfa6f4e77fbb21f312eb6101db6c25acd4d483)
-rw-r--r--src/gallium/winsys/radeon/drm/radeon_drm_winsys.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/gallium/winsys/radeon/drm/radeon_drm_winsys.c b/src/gallium/winsys/radeon/drm/radeon_drm_winsys.c
index b4d5ca0e500..1e4d413379f 100644
--- a/src/gallium/winsys/radeon/drm/radeon_drm_winsys.c
+++ b/src/gallium/winsys/radeon/drm/radeon_drm_winsys.c
@@ -716,8 +716,13 @@ static bool radeon_winsys_unref(struct radeon_winsys *ws)
mtx_lock(&fd_tab_mutex);
destroy = pipe_reference(&rws->reference, NULL);
- if (destroy && fd_tab)
+ if (destroy && fd_tab) {
util_hash_table_remove(fd_tab, intptr_to_pointer(rws->fd));
+ if (util_hash_table_count(fd_tab) == 0) {
+ util_hash_table_destroy(fd_tab);
+ fd_tab = NULL;
+ }
+ }
mtx_unlock(&fd_tab_mutex);
return destroy;