From: Lucas Stach Date: Fri, 9 Jun 2017 16:20:56 +0000 (+0200) Subject: etnaviv: fix memory leak when BO allocation fails X-Git-Url: https://git.libre-soc.org/?p=mesa.git;a=commitdiff_plain;h=4fb9f97047eb1e43c47cb7cacba27ccd20383eff etnaviv: fix memory leak when BO allocation fails The resource struct is already allocated at this point and should be freed properly. Signed-off-by: Lucas Stach Reviewed-by: Philipp Zabel Reviewed-by: Christian Gmeiner Reviewed-by: Wladimir J. van der Laan --- diff --git a/src/gallium/drivers/etnaviv/etnaviv_resource.c b/src/gallium/drivers/etnaviv/etnaviv_resource.c index dfd08707119..97e0a15597f 100644 --- a/src/gallium/drivers/etnaviv/etnaviv_resource.c +++ b/src/gallium/drivers/etnaviv/etnaviv_resource.c @@ -208,7 +208,7 @@ etna_resource_alloc(struct pipe_screen *pscreen, unsigned layout, struct etna_bo *bo = etna_bo_new(screen->dev, size, flags); if (unlikely(bo == NULL)) { BUG("Problem allocating video memory for resource"); - return NULL; + goto free_rsc; } rsc->bo = bo; @@ -223,6 +223,10 @@ etna_resource_alloc(struct pipe_screen *pscreen, unsigned layout, } return &rsc->base; + +free_rsc: + FREE(rsc); + return NULL; } static struct pipe_resource *