Skip to content

Commit

Permalink
Merge pull request FRRouting#17504 from mjstapp/fix_fpm_cancel_race
Browse files Browse the repository at this point in the history
zebra: avoid a race during FPM dplane plugin shutdown
  • Loading branch information
donaldsharp authored Nov 26, 2024
2 parents bd37658 + 277784f commit e8fdbbe
Showing 1 changed file with 34 additions and 0 deletions.
34 changes: 34 additions & 0 deletions zebra/dplane_fpm_nl.c
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,8 @@

static const char *prov_name = "dplane_fpm_nl";

static atomic_bool fpm_cleaning_up;

struct fpm_nl_ctx {
/* data plane connection. */
int socket;
Expand Down Expand Up @@ -524,6 +526,16 @@ static void fpm_connect(struct event *t);

static void fpm_reconnect(struct fpm_nl_ctx *fnc)
{
bool cleaning_p = false;

/* This is being called in the FPM pthread: ensure we don't deadlock
* with similar code that may be run in the main pthread.
*/
if (!atomic_compare_exchange_strong_explicit(
&fpm_cleaning_up, &cleaning_p, true, memory_order_seq_cst,
memory_order_seq_cst))
return;

/* Cancel all zebra threads first. */
event_cancel_async(zrouter.master, &fnc->t_lspreset, NULL);
event_cancel_async(zrouter.master, &fnc->t_lspwalk, NULL);
Expand Down Expand Up @@ -551,6 +563,12 @@ static void fpm_reconnect(struct fpm_nl_ctx *fnc)
EVENT_OFF(fnc->t_read);
EVENT_OFF(fnc->t_write);

/* Reset the barrier value */
cleaning_p = true;
atomic_compare_exchange_strong_explicit(
&fpm_cleaning_up, &cleaning_p, false, memory_order_seq_cst,
memory_order_seq_cst);

/* FPM is disabled, don't attempt to connect. */
if (fnc->disabled)
return;
Expand Down Expand Up @@ -1624,6 +1642,16 @@ static int fpm_nl_start(struct zebra_dplane_provider *prov)

static int fpm_nl_finish_early(struct fpm_nl_ctx *fnc)
{
bool cleaning_p = false;

/* This is being called in the main pthread: ensure we don't deadlock
* with similar code that may be run in the FPM pthread.
*/
if (!atomic_compare_exchange_strong_explicit(
&fpm_cleaning_up, &cleaning_p, true, memory_order_seq_cst,
memory_order_seq_cst))
return 0;

/* Disable all events and close socket. */
EVENT_OFF(fnc->t_lspreset);
EVENT_OFF(fnc->t_lspwalk);
Expand All @@ -1644,6 +1672,12 @@ static int fpm_nl_finish_early(struct fpm_nl_ctx *fnc)
fnc->socket = -1;
}

/* Reset the barrier value */
cleaning_p = true;
atomic_compare_exchange_strong_explicit(
&fpm_cleaning_up, &cleaning_p, false, memory_order_seq_cst,
memory_order_seq_cst);

return 0;
}

Expand Down

0 comments on commit e8fdbbe

Please sign in to comment.