From 0d47f20940003088df0c06f684350cc8da9a7f7a Mon Sep 17 00:00:00 2001 From: Neale Ranns Date: Sun, 9 Jan 2022 13:27:04 +0000 Subject: vppinfra: sparse_vec_free free should free the sparse_vec_header not the embedded vec_header_t Type: fix Signed-off-by: Neale Ranns Change-Id: Ie9532543c4d4439beec8ce097eafa34588ad1266 --- src/vppinfra/sparse_vec.h | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'src/vppinfra/sparse_vec.h') diff --git a/src/vppinfra/sparse_vec.h b/src/vppinfra/sparse_vec.h index fc8b3cf1e8e..2245be88262 100644 --- a/src/vppinfra/sparse_vec.h +++ b/src/vppinfra/sparse_vec.h @@ -223,7 +223,16 @@ sparse_vec_index2 (void *v, *i1_return = is_member1 + d1; } -#define sparse_vec_free(v) vec_free(v) +#define sparse_vec_free(V) \ + do \ + { \ + if (V) \ + { \ + clib_mem_free (sparse_vec_header (V)); \ + V = 0; \ + } \ + } \ + while (0) #define sparse_vec_elt_at_index(v,i) \ vec_elt_at_index ((v), sparse_vec_index ((v), (i))) -- cgit 1.2.3-korg