summaryrefslogtreecommitdiff
path: root/lib/netns_linux.c
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas@opensourcerouting.org>2023-12-12 16:31:52 +0200
committerGitHub <noreply@github.com>2023-12-12 16:31:52 +0200
commitf17cd4587d025df33db6f57a6ac9bf33c65eba88 (patch)
tree049e9a6e4c8b4514ef8c7d437b3ab3a79fa43cb7 /lib/netns_linux.c
parent54625f5f94636fdaec4e6ae76cd8688dbb9c56ce (diff)
parent3d1f0c467b3d8cd9c7cb0fd3ea81165748ee8af0 (diff)
Merge pull request #14985 from donaldsharp/zebra_delete_memory_problems
Zebra delete memory problems
Diffstat (limited to 'lib/netns_linux.c')
-rw-r--r--lib/netns_linux.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/lib/netns_linux.c b/lib/netns_linux.c
index 297e2c5952..bebb5c1f77 100644
--- a/lib/netns_linux.c
+++ b/lib/netns_linux.c
@@ -502,12 +502,19 @@ void ns_init_management(ns_id_t default_ns_id, ns_id_t internal_ns)
void ns_terminate(void)
{
struct ns *ns;
+ struct ns_map_nsid *ns_map;
while (!RB_EMPTY(ns_head, &ns_tree)) {
ns = RB_ROOT(ns_head, &ns_tree);
ns_delete(ns);
}
+
+ while (!RB_EMPTY(ns_map_nsid_head, &ns_map_nsid_list)) {
+ ns_map = RB_ROOT(ns_map_nsid_head, &ns_map_nsid_list);
+ RB_REMOVE(ns_map_nsid_head, &ns_map_nsid_list, ns_map);
+ XFREE(MTYPE_NS, ns_map);
+ }
}
int ns_switch_to_netns(const char *name)