From 46d1028a89555a754644a8ebc0f8d2aa67299a91 Mon Sep 17 00:00:00 2001 From: Carmine Scarpitta Date: Thu, 21 Sep 2023 18:32:06 +0200 Subject: [PATCH] isisd: Fix SRv6 memory leaks When isis_zebra_process_srv6_locator_chunk() returns prematurely due to an error, do not forget to free memory allocated by srv6_locator_chunk_alloc(). Signed-off-by: Carmine Scarpitta --- isisd/isis_zebra.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/isisd/isis_zebra.c b/isisd/isis_zebra.c index 318934b491c4..8252c1ac25a6 100644 --- a/isisd/isis_zebra.c +++ b/isisd/isis_zebra.c @@ -1136,13 +1136,17 @@ static int isis_zebra_process_srv6_locator_chunk(ZAPI_CALLBACK_ARGS) enum srv6_endpoint_behavior_codepoint behavior; bool allocated = false; - if (!isis) + if (!isis) { + srv6_locator_chunk_free(&chunk); return -1; + } /* Decode the received zebra message */ s = zclient->ibuf; - if (zapi_srv6_locator_chunk_decode(s, chunk) < 0) + if (zapi_srv6_locator_chunk_decode(s, chunk) < 0) { + srv6_locator_chunk_free(&chunk); return -1; + } sr_debug( "Received SRv6 locator chunk from zebra: name %s, "