0
0
mirror of https://gitlab.nic.cz/labs/bird.git synced 2024-09-20 12:25:20 +00:00

Main IO loop shouldn't skip sockets when ping is received

This commit is contained in:
Maria Matejka 2021-12-02 11:41:53 +00:00 committed by Maria Matejka
parent c5b6b18413
commit 2117864a87

View File

@ -2200,6 +2200,7 @@ io_loop(void)
{
int poll_tout, timeout;
int nfds, events, pout;
int reload_requested = 0;
timer *t;
sock *s;
node *n;
@ -2216,8 +2217,9 @@ io_loop(void)
timers_fire(&main_birdloop.time, 1);
io_close_event();
restart_poll:
// FIXME
poll_tout = (events ? 0 : 3000); /* Time in milliseconds */
poll_tout = ((reload_requested || events) ? 0 : 3000); /* Time in milliseconds */
if (t = timers_first(&main_birdloop.time))
{
times_update();
@ -2300,16 +2302,23 @@ io_loop(void)
continue;
die("poll: %m");
}
if (pout)
{
if (pfd[0].revents & POLLIN)
if (pout && (pfd[0].revents & POLLIN))
{
/* IO loop reload requested */
pipe_drain(main_birdloop.wakeup_fds[0]);
atomic_exchange_explicit(&main_birdloop.ping_sent, 0, memory_order_acq_rel);
continue;
reload_requested = 1;
goto restart_poll;
}
if (reload_requested)
{
reload_requested = 0;
atomic_exchange_explicit(&main_birdloop.ping_sent, 0, memory_order_acq_rel);
}
if (pout)
{
times_update();
/* guaranteed to be non-empty */