1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00

Merge pull request #19965 from benpicco/sock_udp_recv-ealry

sock/udp: work around gnrc_sock_recv() returning early timeout
This commit is contained in:
benpicco 2023-11-28 12:31:39 +00:00 committed by GitHub
commit db6d918c46
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 32 additions and 1 deletions

View File

@ -25,6 +25,8 @@ BOARD_INSUFFICIENT_MEMORY := \
olimex-msp430-h1611 \ olimex-msp430-h1611 \
olimex-msp430-h2618 \ olimex-msp430-h2618 \
samd10-xmini \ samd10-xmini \
saml10-xpro \
saml11-xpro \
slstk3400a \ slstk3400a \
stk3200 \ stk3200 \
stm32f030f4-demo \ stm32f030f4-demo \

View File

@ -237,6 +237,16 @@ static bool _accept_remote(const sock_udp_t *sock, const udp_hdr_t *hdr,
return true; return true;
} }
static uint32_t _now_us(void)
{
#ifdef MODULE_ZTIMER_USEC
return ztimer_now(ZTIMER_USEC);
#endif
#ifdef MODULE_ZTIMER_MSEC
return ztimer_now(ZTIMER_MSEC) * US_PER_MS;
#endif
}
ssize_t sock_udp_recv_buf_aux(sock_udp_t *sock, void **data, void **buf_ctx, ssize_t sock_udp_recv_buf_aux(sock_udp_t *sock, void **data, void **buf_ctx,
uint32_t timeout, sock_udp_ep_t *remote, uint32_t timeout, sock_udp_ep_t *remote,
sock_udp_aux_rx_t *aux) sock_udp_aux_rx_t *aux)
@ -274,7 +284,26 @@ ssize_t sock_udp_recv_buf_aux(sock_udp_t *sock, void **data, void **buf_ctx,
_aux.rssi = &aux->rssi; _aux.rssi = &aux->rssi;
} }
#endif #endif
unsigned now = _now_us();
while (1) {
res = gnrc_sock_recv((gnrc_sock_reg_t *)sock, &pkt, timeout, &tmp, &_aux); res = gnrc_sock_recv((gnrc_sock_reg_t *)sock, &pkt, timeout, &tmp, &_aux);
if (res != -ETIMEDOUT) {
break;
}
/* HACK: gnrc_sock_recv() sometimes returns -ETIMEDOUT too early */
uint32_t time_elapsed = _now_us() - now;
if (time_elapsed < (timeout - timeout/10)) {
DEBUG("gnrc_sock_udp: timeout happened %"PRIu32" µs early\n",
timeout - time_elapsed);
timeout -= time_elapsed;
now = _now_us();
continue;
}
break;
}
if (res < 0) { if (res < 0) {
return res; return res;
} }