From ef5e8e38bd38f26e2da2f6f0a2d720468c935280 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Wed, 8 Mar 2023 09:38:53 +0100 Subject: usock: fix poll return code check errno needs to be compared against EINTR/EAGAIN instead of the return code, and only if the return code is < 0. Signed-off-by: Felix Fietkau --- usock.c | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/usock.c b/usock.c index 0ce5390..15b6988 100644 --- a/usock.c +++ b/usock.c @@ -120,10 +120,7 @@ static int poll_restart(struct pollfd *fds, int nfds, int timeout) while (1) { ret = poll(fds, nfds, timeout); - if (ret == EAGAIN) - continue; - - if (ret != EINTR) + if (ret >= 0 || (errno != EINTR && errno != EAGAIN)) return ret; clock_gettime(CLOCK_MONOTONIC, &cur); -- cgit v1.2.1