1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-07 17:17:44 +03:00

resolved: fix fastopen fallback

We should not invalidate the socket address size before we use it.

Fixes: #34579
(cherry picked from commit 5699e4c2d470a12c922c4b7c86a8987837911626)
(cherry picked from commit 964f7772ad0ff637db80ae0a9e0afb41a40f5b04)
This commit is contained in:
Lennart Poettering 2024-10-07 13:03:51 +02:00 committed by Luca Boccassi
parent 1d8a639e53
commit 4dca5688cb

View File

@ -205,6 +205,7 @@ static int dns_stream_identify(DnsStream *s) {
ssize_t dns_stream_writev(DnsStream *s, const struct iovec *iov, size_t iovcnt, int flags) {
ssize_t m;
int r;
assert(s);
assert(iov);
@ -224,12 +225,14 @@ ssize_t dns_stream_writev(DnsStream *s, const struct iovec *iov, size_t iovcnt,
m = sendmsg(s->fd, &hdr, MSG_FASTOPEN);
if (m < 0) {
if (errno == EOPNOTSUPP) {
s->tfo_salen = 0;
if (connect(s->fd, &s->tfo_address.sa, s->tfo_salen) < 0)
return -errno;
if (ERRNO_IS_NOT_SUPPORTED(errno)) {
/* MSG_FASTOPEN not supported? Then try to connect() traditionally */
r = RET_NERRNO(connect(s->fd, &s->tfo_address.sa, s->tfo_salen));
s->tfo_salen = 0; /* connection is made */
if (r < 0 && r != -EINPROGRESS)
return r;
return -EAGAIN;
return -EAGAIN; /* In case of EINPROGRESS, EAGAIN or success: return EAGAIN, so that caller calls us again */
}
if (errno == EINPROGRESS)
return -EAGAIN;