Skip to content

Commit

Permalink
Merge pull request #15539 from donaldsharp/cleanup_leaky_sieve
Browse files Browse the repository at this point in the history
zebra: Cleanup leaked memory on shutdown from GR code
  • Loading branch information
ton31337 authored Mar 13, 2024
2 parents dfa2776 + 9ef76cf commit a3df790
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 1 deletion.
10 changes: 10 additions & 0 deletions zebra/zebra_gr.c
Original file line number Diff line number Diff line change
Expand Up @@ -298,6 +298,16 @@ struct zebra_gr_afi_clean {
* Functions to deal with capabilities
*/

void zebra_gr_client_final_shutdown(struct zserv *client)
{
struct client_gr_info *info;

while (!TAILQ_EMPTY(&client->gr_info_queue)) {
info = TAILQ_FIRST(&client->gr_info_queue);
zebra_gr_client_info_delete(client, info);
}
}

/*
* Function to decode and call appropriate functions
* to handle client capabilities.
Expand Down
6 changes: 5 additions & 1 deletion zebra/zserv.c
Original file line number Diff line number Diff line change
Expand Up @@ -675,10 +675,14 @@ static void zserv_client_free(struct zserv *client)
* If any instance are graceful restart enabled,
* client is not deleted
*/
if (DYNAMIC_CLIENT_GR_DISABLED(client)) {
if (DYNAMIC_CLIENT_GR_DISABLED(client) || zebra_router_in_shutdown()) {
if (IS_ZEBRA_DEBUG_EVENT)
zlog_debug("%s: Deleting client %s", __func__,
zebra_route_string(client->proto));

if (zebra_router_in_shutdown())
zebra_gr_client_final_shutdown(client);

zserv_client_delete(client);
} else {
/* Handle cases where client has GR instance. */
Expand Down
1 change: 1 addition & 0 deletions zebra/zserv.h
Original file line number Diff line number Diff line change
Expand Up @@ -378,6 +378,7 @@ __attribute__((__noreturn__)) void zebra_finalize(struct event *event);
/*
* Graceful restart functions.
*/
extern void zebra_gr_client_final_shutdown(struct zserv *client);
extern int zebra_gr_client_disconnect(struct zserv *client);
extern void zebra_gr_client_reconnect(struct zserv *client);
extern void zebra_gr_stale_client_cleanup(struct list *client_list);
Expand Down

0 comments on commit a3df790

Please sign in to comment.