From: Edward O'Callaghan Date: Tue, 11 Oct 2016 11:43:07 +0000 (+1100) Subject: radv/winsys: Fix mem leak at failed do_winsys_init() call site X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e0641c61ca5cb8bba2e4cb5a0a6eede74f11ebc6;p=mesa.git radv/winsys: Fix mem leak at failed do_winsys_init() call site Probably unlikely however ensure we don't leak a heap allocation on the fail path. V.2: also fix missing 'amdgpu_device_deinitialize()' calls (Emil Velikov). Signed-off-by: Edward O'Callaghan Reviewed-by: Emil Velikov Signed-off-by: Dave Airlie --- diff --git a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c index 0ce44acd39d..04561007258 100644 --- a/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c +++ b/src/amd/vulkan/winsys/amdgpu/radv_amdgpu_winsys.c @@ -337,13 +337,13 @@ radv_amdgpu_winsys_create(int fd) ws = calloc(1, sizeof(struct radv_amdgpu_winsys)); if (!ws) - return NULL; + goto fail; ws->dev = dev; ws->info.drm_major = drm_major; ws->info.drm_minor = drm_minor; if (!do_winsys_init(ws, fd)) - goto fail; + goto winsys_fail; ws->debug_all_bos = getenv("RADV_DEBUG_ALL_BOS") ? true : false; LIST_INITHEAD(&ws->global_bo_list); @@ -355,6 +355,10 @@ radv_amdgpu_winsys_create(int fd) radv_amdgpu_surface_init_functions(ws); return &ws->base; + +winsys_fail: + free(ws); fail: + amdgpu_device_deinitialize(dev); return NULL; }