From 9be90c0f84e8ffce6bbd89222843e9da3d634f68 Mon Sep 17 00:00:00 2001 From: Maria Matejka Date: Wed, 19 Jun 2024 12:02:34 +0200 Subject: [PATCH] Fixed a race condition in rcu-domain blocking --- sysdep/unix/domain.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/sysdep/unix/domain.c b/sysdep/unix/domain.c index 2817455f..4e6d8a61 100644 --- a/sysdep/unix/domain.c +++ b/sysdep/unix/domain.c @@ -137,6 +137,9 @@ void do_lock(struct domain_generic *dg, struct domain_generic **lsp) void do_unlock(struct domain_generic *dg, struct domain_generic **lsp) { + if (dg->forbidden_when_reading_rcu) + ASSERT_DIE(rcu_blocked--); + if ((char *) lsp - (char *) &locking_stack != dg->order) bug("Trying to unlock on bad position: order=%u, lsp=%p, base=%p", dg->order, lsp, &locking_stack); @@ -150,6 +153,5 @@ void do_unlock(struct domain_generic *dg, struct domain_generic **lsp) dg->prev = NULL; pthread_mutex_unlock(&dg->mutex); - if (dg->forbidden_when_reading_rcu) - ASSERT_DIE(rcu_blocked--); + /* From here on, the dg pointer is invalid! */ }