From 14ad24c7b804efeaae54b8b21cfda61af9f80d94 Mon Sep 17 00:00:00 2001 From: Zhiqiang Liu Date: Sun, 13 Jun 2021 14:53:27 +0800 Subject: [PATCH] idxd: fix one memleak problem in spdk_idxd_get_channel() In spdk_idxd_get_channel(), if chan->batch_base is allocated faild, we should free chan before returning NULL. Signed-off-by: Zhiqiang Liu Change-Id: Ia652c334aead592429c1171da73d67160879686d Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/8301 Community-CI: Mellanox Build Bot Reviewed-by: Aleksey Marchuk Reviewed-by: Changpeng Liu Tested-by: SPDK CI Jenkins --- lib/idxd/idxd.c | 1 + 1 file changed, 1 insertion(+) diff --git a/lib/idxd/idxd.c b/lib/idxd/idxd.c index d91933558..95937d340 100644 --- a/lib/idxd/idxd.c +++ b/lib/idxd/idxd.c @@ -108,6 +108,7 @@ spdk_idxd_get_channel(struct spdk_idxd_device *idxd) chan->batch_base = calloc(NUM_BATCHES_PER_CHANNEL, sizeof(struct idxd_batch)); if (chan->batch_base == NULL) { SPDK_ERRLOG("Failed to allocate batch pool\n"); + free(chan); return NULL; }