X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=src%2Fvlib%2Fmain.c;h=f915aa41b3bce7f37f84742d2c3344e53aae0558;hb=d47c509af13ddcb80f82aebd25dc4f40cc778a0e;hp=d32ca7b8ea2d269a46c17e69b2f76902bf687150;hpb=ba7992aa62523d014b55802463fb3357c7099b70;p=vpp.git 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;