diff options
| author | Donatas Abraitis <donatas@opensourcerouting.org> | 2023-12-12 16:31:52 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-12-12 16:31:52 +0200 |
| commit | f17cd4587d025df33db6f57a6ac9bf33c65eba88 (patch) | |
| tree | 049e9a6e4c8b4514ef8c7d437b3ab3a79fa43cb7 /lib/netns_linux.c | |
| parent | 54625f5f94636fdaec4e6ae76cd8688dbb9c56ce (diff) | |
| parent | 3d1f0c467b3d8cd9c7cb0fd3ea81165748ee8af0 (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.c | 7 |
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) |
