Skip to content

Commit

Permalink
daemon/session2: avoid incorrectly generated errors
Browse files Browse the repository at this point in the history
The _try_ functions return different values,
and the code around didn't deal with that.
  • Loading branch information
vcunat committed Sep 23, 2024
1 parent a3d84e2 commit 805dae9
Showing 1 changed file with 4 additions and 0 deletions.
4 changes: 4 additions & 0 deletions daemon/session2.c
Original file line number Diff line number Diff line change
Expand Up @@ -1445,6 +1445,8 @@ static int session2_transport_pushv(struct session2 *s,
} else {
int ret = uv_udp_try_send((uv_udp_t*)handle,
(uv_buf_t *)iov, iovcnt, comm->comm_addr);
if (ret > 0) // equals buffer size, only confuses us
ret = 0;
if (ret == UV_EAGAIN) {
ret = kr_error(ENOBUFS);
session2_event(s, PROTOLAYER_EVENT_OS_BUFFER_FULL, NULL);
Expand Down Expand Up @@ -1476,6 +1478,8 @@ static int session2_transport_pushv(struct session2 *s,
ret = kr_error(ENOBUFS);
session2_event(s, PROTOLAYER_EVENT_OS_BUFFER_FULL, NULL);
}
else if (ret > 0) // iovec_sum was checked, let's not get confused anymore
ret = 0;

if (false && ret == UV_EAGAIN) {
uv_write_t *req = malloc(sizeof(*req));
Expand Down

0 comments on commit 805dae9

Please sign in to comment.