From: Dave Barach Date: Fri, 19 Jan 2018 18:09:20 +0000 (-0500) Subject: Fix MP hazard in interrupt node scheduling X-Git-Tag: v18.04-rc1~462 X-Git-Url: https://gerrit.fd.io/r/gitweb?a=commitdiff_plain;ds=sidebyside;h=d47c509af13ddcb80f82aebd25dc4f40cc778a0e;p=vpp.git Fix MP hazard in interrupt node scheduling Change-Id: Iff14ed6ffd822eb2286aac6af467d9c8660e3d81 Signed-off-by: Dave Barach --- diff --git a/src/vlib/main.c b/src/vlib/main.c index d32ca7b8ea2..f915aa41b3b 100644 --- a/src/vlib/main.c +++ b/src/vlib/main.c @@ -1514,13 +1514,19 @@ vlib_main_or_worker_loop (vlib_main_t * vm, int is_main) /* Next handle interrupts. */ { + /* unlocked read, for performance */ uword l = _vec_len (nm->pending_interrupt_node_runtime_indices); uword i; - if (l > 0) + if (PREDICT_FALSE (l > 0)) { u32 *tmp; if (!is_main) - clib_spinlock_lock (&nm->pending_interrupt_lock); + { + clib_spinlock_lock (&nm->pending_interrupt_lock); + /* Re-read w/ lock held, in case another thread added an item */ + l = _vec_len (nm->pending_interrupt_node_runtime_indices); + } + tmp = nm->pending_interrupt_node_runtime_indices; nm->pending_interrupt_node_runtime_indices = last_node_runtime_indices;