From 4fb9f97047eb1e43c47cb7cacba27ccd20383eff Mon Sep 17 00:00:00 2001 From: Lucas Stach Date: Fri, 9 Jun 2017 18:20:56 +0200 Subject: [PATCH] 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 --- src/gallium/drivers/etnaviv/etnaviv_resource.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) 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 * -- 2.30.2