Add a failsafe to prevent epoll busy-spin.
This commit is contained in:
parent
6c136c3f85
commit
8273b383ab
31
src/ndhc.c
31
src/ndhc.c
@ -265,7 +265,8 @@ static void do_ndhc_work(void)
|
|||||||
struct dhcpmsg dhcp_packet;
|
struct dhcpmsg dhcp_packet;
|
||||||
struct epoll_event events[1];
|
struct epoll_event events[1];
|
||||||
long long nowts;
|
long long nowts;
|
||||||
int timeout;
|
int timeout = 0;
|
||||||
|
bool had_event;
|
||||||
|
|
||||||
cs.epollFd = epoll_create1(0);
|
cs.epollFd = epoll_create1(0);
|
||||||
if (cs.epollFd < 0)
|
if (cs.epollFd < 0)
|
||||||
@ -282,9 +283,9 @@ static void do_ndhc_work(void)
|
|||||||
if (client_config.enable_rfkill && cs.rfkillFd != -1)
|
if (client_config.enable_rfkill && cs.rfkillFd != -1)
|
||||||
epoll_add(cs.epollFd, cs.rfkillFd);
|
epoll_add(cs.epollFd, cs.rfkillFd);
|
||||||
start_dhcp_listen(&cs);
|
start_dhcp_listen(&cs);
|
||||||
timeout = 0;
|
|
||||||
|
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
had_event = false;
|
||||||
int maxi = epoll_wait(cs.epollFd, events, 1, timeout);
|
int maxi = epoll_wait(cs.epollFd, events, 1, timeout);
|
||||||
if (maxi < 0) {
|
if (maxi < 0) {
|
||||||
if (errno == EINTR)
|
if (errno == EINTR)
|
||||||
@ -301,6 +302,7 @@ static void do_ndhc_work(void)
|
|||||||
int sev_signal = SIGNAL_NONE;
|
int sev_signal = SIGNAL_NONE;
|
||||||
bool force_fingerprint = false;
|
bool force_fingerprint = false;
|
||||||
for (int i = 0; i < maxi; ++i) {
|
for (int i = 0; i < maxi; ++i) {
|
||||||
|
had_event = true;
|
||||||
int fd = events[i].data.fd;
|
int fd = events[i].data.fd;
|
||||||
if (fd == cs.signalFd) {
|
if (fd == cs.signalFd) {
|
||||||
if (!(events[i].events & EPOLLIN))
|
if (!(events[i].events & EPOLLIN))
|
||||||
@ -391,21 +393,26 @@ static void do_ndhc_work(void)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int prev_timeout = timeout;
|
||||||
|
|
||||||
arp_wake_ts = arp_get_wake_ts();
|
arp_wake_ts = arp_get_wake_ts();
|
||||||
if (arp_wake_ts < 0) {
|
if (arp_wake_ts < 0 && cs.dhcp_wake_ts < 0) {
|
||||||
if (cs.dhcp_wake_ts != -1) {
|
timeout = -1;
|
||||||
timeout = cs.dhcp_wake_ts - nowts;
|
continue;
|
||||||
if (timeout < 0)
|
} else if (arp_wake_ts < 0) {
|
||||||
timeout = 0;
|
timeout = cs.dhcp_wake_ts - nowts;
|
||||||
} else
|
} else if (cs.dhcp_wake_ts < 0) {
|
||||||
timeout = -1;
|
timeout = arp_wake_ts - nowts;
|
||||||
} else {
|
} else {
|
||||||
// If cs.dhcp_wake_ts is -1 then we want to sleep anyway.
|
|
||||||
timeout = (arp_wake_ts < cs.dhcp_wake_ts ?
|
timeout = (arp_wake_ts < cs.dhcp_wake_ts ?
|
||||||
arp_wake_ts : cs.dhcp_wake_ts) - nowts;
|
arp_wake_ts : cs.dhcp_wake_ts) - nowts;
|
||||||
if (timeout < 0)
|
|
||||||
timeout = 0;
|
|
||||||
}
|
}
|
||||||
|
if (timeout < 0)
|
||||||
|
timeout = 0;
|
||||||
|
|
||||||
|
// Failsafe to prevent busy-spin.
|
||||||
|
if (prev_timeout == 0 && !had_event)
|
||||||
|
timeout = 10;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user