From 8a4d952d1074e648a99e44ed558a6f0f5b4460a7 Mon Sep 17 00:00:00 2001 From: Vinson Lee Date: Thu, 31 Jan 2013 23:45:13 -0800 Subject: [PATCH] r600g: Fix memory leak. MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit Fixes resource leak defect reported by Coverity. Signed-off-by: Vinson Lee Reviewed-by: Marek Olšák Reviewed-by: Brian Paul --- src/gallium/drivers/r600/r600_hw_context.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/gallium/drivers/r600/r600_hw_context.c b/src/gallium/drivers/r600/r600_hw_context.c index a89f23069d3..ebcd682bc81 100644 --- a/src/gallium/drivers/r600/r600_hw_context.c +++ b/src/gallium/drivers/r600/r600_hw_context.c @@ -201,8 +201,10 @@ int r600_context_add_block(struct r600_context *ctx, const struct r600_reg *reg, /* create block table if it doesn't exist */ if (!range->blocks) range->blocks = calloc(1 << HASH_SHIFT, sizeof(void *)); - if (!range->blocks) + if (!range->blocks) { + free(block); return -1; + } range->blocks[CTX_BLOCK_ID(reg[i + j].offset)] = block; } -- 2.30.2