From 571c4f69bfbcf437d848b332bb2f4995fea2347d Mon Sep 17 00:00:00 2001 From: Maria Matejka Date: Fri, 24 Feb 2023 09:13:35 +0100 Subject: More efficient IO loop event execution to avoid long loops If there are lots of loops in a single thread and only some of the loops are actually active, the other loops are now kept aside and not checked until they actually get some timers, events or active sockets. This should help with extreme loads like 100k tables and protocols. Also ping and loop pickup mechanism was allowing subtle race conditions. Now properly handling collisions between loop ping and pickup. --- lib/locking.h | 1 + 1 file changed, 1 insertion(+) (limited to 'lib/locking.h') diff --git a/lib/locking.h b/lib/locking.h index 7e014bd0..6bed14bf 100644 --- a/lib/locking.h +++ b/lib/locking.h @@ -13,6 +13,7 @@ struct domain_generic; /* Here define the global lock order; first to last. */ struct lock_order { + struct domain_generic *meta; struct domain_generic *the_bird; struct domain_generic *control; struct domain_generic *proto; -- cgit v1.2.3