tree-wide: use setsockopt_int() more
This commit is contained in:
parent
986c8af1b8
commit
9e5b649655
|
@ -839,10 +839,11 @@ int fd_inc_sndbuf(int fd, size_t n) {
|
|||
|
||||
/* If we have the privileges we will ignore the kernel limit. */
|
||||
|
||||
value = (int) n;
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &value, sizeof(value)) < 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUFFORCE, &value, sizeof(value)) < 0)
|
||||
return -errno;
|
||||
if (setsockopt_int(fd, SOL_SOCKET, SO_SNDBUF, n) < 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_SNDBUFFORCE, n);
|
||||
if (r < 0)
|
||||
return r;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
@ -857,10 +858,12 @@ int fd_inc_rcvbuf(int fd, size_t n) {
|
|||
|
||||
/* If we have the privileges we will ignore the kernel limit. */
|
||||
|
||||
value = (int) n;
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &value, sizeof(value)) < 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUFFORCE, &value, sizeof(value)) < 0)
|
||||
return -errno;
|
||||
if (setsockopt_int(fd, SOL_SOCKET, SO_RCVBUF, n) < 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_RCVBUFFORCE, n);
|
||||
if (r < 0)
|
||||
return r;
|
||||
}
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
|
|
@ -1020,27 +1020,27 @@ static void socket_apply_socket_options(Socket *s, int fd) {
|
|||
}
|
||||
|
||||
if (s->keep_alive_time > 0) {
|
||||
int value = s->keep_alive_time / USEC_PER_SEC;
|
||||
if (setsockopt(fd, SOL_TCP, TCP_KEEPIDLE, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "TCP_KEEPIDLE failed: %m");
|
||||
r = setsockopt_int(fd, SOL_TCP, TCP_KEEPIDLE, s->keep_alive_time / USEC_PER_SEC);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "TCP_KEEPIDLE failed: %m");
|
||||
}
|
||||
|
||||
if (s->keep_alive_interval > 0) {
|
||||
int value = s->keep_alive_interval / USEC_PER_SEC;
|
||||
if (setsockopt(fd, SOL_TCP, TCP_KEEPINTVL, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "TCP_KEEPINTVL failed: %m");
|
||||
r = setsockopt_int(fd, SOL_TCP, TCP_KEEPINTVL, s->keep_alive_interval / USEC_PER_SEC);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "TCP_KEEPINTVL failed: %m");
|
||||
}
|
||||
|
||||
if (s->keep_alive_cnt > 0) {
|
||||
int value = s->keep_alive_cnt;
|
||||
if (setsockopt(fd, SOL_TCP, TCP_KEEPCNT, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "TCP_KEEPCNT failed: %m");
|
||||
r = setsockopt_int(fd, SOL_TCP, TCP_KEEPCNT, s->keep_alive_cnt);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "TCP_KEEPCNT failed: %m");
|
||||
}
|
||||
|
||||
if (s->defer_accept > 0) {
|
||||
int value = s->defer_accept / USEC_PER_SEC;
|
||||
if (setsockopt(fd, SOL_TCP, TCP_DEFER_ACCEPT, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "TCP_DEFER_ACCEPT failed: %m");
|
||||
r = setsockopt_int(fd, SOL_TCP, TCP_DEFER_ACCEPT, s->defer_accept / USEC_PER_SEC);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "TCP_DEFER_ACCEPT failed: %m");
|
||||
}
|
||||
|
||||
if (s->no_delay) {
|
||||
|
@ -1073,48 +1073,53 @@ static void socket_apply_socket_options(Socket *s, int fd) {
|
|||
log_unit_warning_errno(UNIT(s), r, "SO_PASSSEC failed: %m");
|
||||
}
|
||||
|
||||
if (s->priority >= 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_PRIORITY, &s->priority, sizeof(s->priority)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "SO_PRIORITY failed: %m");
|
||||
if (s->priority >= 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_PRIORITY, s->priority);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "SO_PRIORITY failed: %m");
|
||||
}
|
||||
|
||||
if (s->receive_buffer > 0) {
|
||||
int value = (int) s->receive_buffer;
|
||||
|
||||
/* We first try with SO_RCVBUFFORCE, in case we have the perms for that */
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUFFORCE, &value, sizeof(value)) < 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_RCVBUF, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "SO_RCVBUF failed: %m");
|
||||
if (setsockopt_int(fd, SOL_SOCKET, SO_RCVBUFFORCE, s->receive_buffer) < 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_RCVBUF, s->receive_buffer);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "SO_RCVBUF failed: %m");
|
||||
}
|
||||
}
|
||||
|
||||
if (s->send_buffer > 0) {
|
||||
int value = (int) s->send_buffer;
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUFFORCE, &value, sizeof(value)) < 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_SNDBUF, &value, sizeof(value)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "SO_SNDBUF failed: %m");
|
||||
if (setsockopt_int(fd, SOL_SOCKET, SO_SNDBUFFORCE, s->send_buffer) < 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_SNDBUF, s->send_buffer);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "SO_SNDBUF failed: %m");
|
||||
}
|
||||
}
|
||||
|
||||
if (s->mark >= 0)
|
||||
if (setsockopt(fd, SOL_SOCKET, SO_MARK, &s->mark, sizeof(s->mark)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "SO_MARK failed: %m");
|
||||
if (s->mark >= 0) {
|
||||
r = setsockopt_int(fd, SOL_SOCKET, SO_MARK, s->mark);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "SO_MARK failed: %m");
|
||||
}
|
||||
|
||||
if (s->ip_tos >= 0)
|
||||
if (setsockopt(fd, IPPROTO_IP, IP_TOS, &s->ip_tos, sizeof(s->ip_tos)) < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "IP_TOS failed: %m");
|
||||
if (s->ip_tos >= 0) {
|
||||
r = setsockopt_int(fd, IPPROTO_IP, IP_TOS, s->ip_tos);
|
||||
if (r < 0)
|
||||
log_unit_warning_errno(UNIT(s), r, "IP_TOS failed: %m");
|
||||
}
|
||||
|
||||
if (s->ip_ttl >= 0) {
|
||||
int x;
|
||||
|
||||
r = setsockopt(fd, IPPROTO_IP, IP_TTL, &s->ip_ttl, sizeof(s->ip_ttl));
|
||||
r = setsockopt_int(fd, IPPROTO_IP, IP_TTL, s->ip_ttl);
|
||||
|
||||
if (socket_ipv6_is_supported())
|
||||
x = setsockopt(fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, &s->ip_ttl, sizeof(s->ip_ttl));
|
||||
else {
|
||||
x = -1;
|
||||
errno = EAFNOSUPPORT;
|
||||
}
|
||||
x = setsockopt_int(fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, s->ip_ttl);
|
||||
else
|
||||
x = -EAFNOSUPPORT;
|
||||
|
||||
if (r < 0 && x < 0)
|
||||
log_unit_warning_errno(UNIT(s), errno, "IP_TTL/IPV6_UNICAST_HOPS failed: %m");
|
||||
log_unit_warning_errno(UNIT(s), r, "IP_TTL/IPV6_UNICAST_HOPS failed: %m");
|
||||
}
|
||||
|
||||
if (s->tcp_congestion)
|
||||
|
|
|
@ -149,15 +149,15 @@ int dhcp_network_bind_udp_socket(int ifindex, be32_t address, uint16_t port) {
|
|||
};
|
||||
_cleanup_close_ int s = -1;
|
||||
char ifname[IF_NAMESIZE] = "";
|
||||
int r, tos = IPTOS_CLASS_CS6;
|
||||
int r;
|
||||
|
||||
s = socket(AF_INET, SOCK_DGRAM | SOCK_CLOEXEC | SOCK_NONBLOCK, 0);
|
||||
if (s < 0)
|
||||
return -errno;
|
||||
|
||||
r = setsockopt(s, IPPROTO_IP, IP_TOS, &tos, sizeof(tos));
|
||||
r = setsockopt_int(s, IPPROTO_IP, IP_TOS, IPTOS_CLASS_CS6);
|
||||
if (r < 0)
|
||||
return -errno;
|
||||
return r;
|
||||
|
||||
r = setsockopt_int(s, SOL_SOCKET, SO_REUSEADDR, true);
|
||||
if (r < 0)
|
||||
|
|
|
@ -33,7 +33,6 @@ static int icmp6_bind_router_message(const struct icmp6_filter *filter,
|
|||
int index = mreq->ipv6mr_interface;
|
||||
_cleanup_close_ int s = -1;
|
||||
char ifname[IF_NAMESIZE] = "";
|
||||
static const int hops = 255;
|
||||
int r;
|
||||
|
||||
s = socket(AF_INET6, SOCK_RAW | SOCK_CLOEXEC | SOCK_NONBLOCK, IPPROTO_ICMPV6);
|
||||
|
@ -52,21 +51,21 @@ static int icmp6_bind_router_message(const struct icmp6_filter *filter,
|
|||
IPV6_PKTINFO socket option also applies for ICMPv6 multicast.
|
||||
Empirical experiments indicates otherwise and therefore an
|
||||
IPV6_MULTICAST_IF socket option is used here instead */
|
||||
r = setsockopt(s, IPPROTO_IPV6, IPV6_MULTICAST_IF, &index, sizeof(index));
|
||||
r = setsockopt_int(s, IPPROTO_IPV6, IPV6_MULTICAST_IF, index);
|
||||
if (r < 0)
|
||||
return -errno;
|
||||
return r;
|
||||
|
||||
r = setsockopt_int(s, IPPROTO_IPV6, IPV6_MULTICAST_LOOP, false);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
r = setsockopt(s, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, &hops, sizeof(hops));
|
||||
r = setsockopt_int(s, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, 255);
|
||||
if (r < 0)
|
||||
return -errno;
|
||||
return r;
|
||||
|
||||
r = setsockopt(s, IPPROTO_IPV6, IPV6_UNICAST_HOPS, &hops, sizeof(hops));
|
||||
r = setsockopt_int(s, IPPROTO_IPV6, IPV6_UNICAST_HOPS, 255);
|
||||
if (r < 0)
|
||||
return -errno;
|
||||
return r;
|
||||
|
||||
r = setsockopt_int(s, SOL_IPV6, IPV6_RECVHOPLIMIT, true);
|
||||
if (r < 0)
|
||||
|
|
|
@ -88,14 +88,16 @@ int device_monitor_allow_unicast_sender(sd_device_monitor *m, sd_device_monitor
|
|||
}
|
||||
|
||||
_public_ int sd_device_monitor_set_receive_buffer_size(sd_device_monitor *m, size_t size) {
|
||||
int n = (int) size;
|
||||
int r, n = (int) size;
|
||||
|
||||
assert_return(m, -EINVAL);
|
||||
assert_return((size_t) n != size, -EINVAL);
|
||||
|
||||
if (setsockopt(m->sock, SOL_SOCKET, SO_RCVBUF, &n, sizeof(n)) < 0 &&
|
||||
setsockopt(m->sock, SOL_SOCKET, SO_RCVBUFFORCE, &n, sizeof(n)) < 0)
|
||||
return -errno;
|
||||
if (setsockopt_int(m->sock, SOL_SOCKET, SO_RCVBUF, n) < 0) {
|
||||
r = setsockopt_int(m->sock, SOL_SOCKET, SO_RCVBUFFORCE, n);
|
||||
if (r < 0)
|
||||
return r;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -115,7 +115,6 @@ int manager_llmnr_ipv4_udp_fd(Manager *m) {
|
|||
.in.sin_family = AF_INET,
|
||||
.in.sin_port = htobe16(LLMNR_PORT),
|
||||
};
|
||||
static const int pmtu = IP_PMTUDISC_DONT, ttl = 255;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -128,15 +127,15 @@ int manager_llmnr_ipv4_udp_fd(Manager *m) {
|
|||
return log_error_errno(errno, "LLMNR-IPv4(UDP): Failed to create socket: %m");
|
||||
|
||||
/* RFC 4795, section 2.5 recommends setting the TTL of UDP packets to 255. */
|
||||
r = setsockopt(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_TTL, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_TTL, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv4(UDP): Failed to set IP_TTL: %m");
|
||||
log_error_errno(r, "LLMNR-IPv4(UDP): Failed to set IP_TTL: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
r = setsockopt(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_MULTICAST_TTL, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv4(UDP): Failed to set IP_MULTICAST_TTL: %m");
|
||||
log_error_errno(r, "LLMNR-IPv4(UDP): Failed to set IP_MULTICAST_TTL: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -159,9 +158,9 @@ int manager_llmnr_ipv4_udp_fd(Manager *m) {
|
|||
}
|
||||
|
||||
/* Disable Don't-Fragment bit in the IP header */
|
||||
r = setsockopt(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_MTU_DISCOVER, &pmtu, sizeof(pmtu));
|
||||
r = setsockopt_int(m->llmnr_ipv4_udp_fd, IPPROTO_IP, IP_MTU_DISCOVER, IP_PMTUDISC_DONT);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv4(UDP): Failed to set IP_MTU_DISCOVER: %m");
|
||||
log_error_errno(r, "LLMNR-IPv4(UDP): Failed to set IP_MTU_DISCOVER: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -214,7 +213,6 @@ int manager_llmnr_ipv6_udp_fd(Manager *m) {
|
|||
.in6.sin6_family = AF_INET6,
|
||||
.in6.sin6_port = htobe16(LLMNR_PORT),
|
||||
};
|
||||
static const int ttl = 255;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -226,16 +224,16 @@ int manager_llmnr_ipv6_udp_fd(Manager *m) {
|
|||
if (m->llmnr_ipv6_udp_fd < 0)
|
||||
return log_error_errno(errno, "LLMNR-IPv6(UDP): Failed to create socket: %m");
|
||||
|
||||
r = setsockopt(m->llmnr_ipv6_udp_fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->llmnr_ipv6_udp_fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv6(UDP): Failed to set IPV6_UNICAST_HOPS: %m");
|
||||
log_error_errno(r, "LLMNR-IPv6(UDP): Failed to set IPV6_UNICAST_HOPS: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
/* RFC 4795, section 2.5 recommends setting the TTL of UDP packets to 255. */
|
||||
r = setsockopt(m->llmnr_ipv6_udp_fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->llmnr_ipv6_udp_fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv6(UDP): Failed to set IPV6_MULTICAST_HOPS: %m");
|
||||
log_error_errno(r, "LLMNR-IPv6(UDP): Failed to set IPV6_MULTICAST_HOPS: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -355,7 +353,6 @@ int manager_llmnr_ipv4_tcp_fd(Manager *m) {
|
|||
.in.sin_family = AF_INET,
|
||||
.in.sin_port = htobe16(LLMNR_PORT),
|
||||
};
|
||||
static const int pmtu = IP_PMTUDISC_DONT;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -387,9 +384,9 @@ int manager_llmnr_ipv4_tcp_fd(Manager *m) {
|
|||
}
|
||||
|
||||
/* Disable Don't-Fragment bit in the IP header */
|
||||
r = setsockopt(m->llmnr_ipv4_tcp_fd, IPPROTO_IP, IP_MTU_DISCOVER, &pmtu, sizeof(pmtu));
|
||||
r = setsockopt_int(m->llmnr_ipv4_tcp_fd, IPPROTO_IP, IP_MTU_DISCOVER, IP_PMTUDISC_DONT);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "LLMNR-IPv4(TCP): Failed to set IP_MTU_DISCOVER: %m");
|
||||
log_error_errno(r, "LLMNR-IPv4(TCP): Failed to set IP_MTU_DISCOVER: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
|
|
@ -339,7 +339,6 @@ int manager_mdns_ipv4_fd(Manager *m) {
|
|||
.in.sin_family = AF_INET,
|
||||
.in.sin_port = htobe16(MDNS_PORT),
|
||||
};
|
||||
static const int pmtu = IP_PMTUDISC_DONT, ttl = 255;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -351,15 +350,15 @@ int manager_mdns_ipv4_fd(Manager *m) {
|
|||
if (m->mdns_ipv4_fd < 0)
|
||||
return log_error_errno(errno, "mDNS-IPv4: Failed to create socket: %m");
|
||||
|
||||
r = setsockopt(m->mdns_ipv4_fd, IPPROTO_IP, IP_TTL, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->mdns_ipv4_fd, IPPROTO_IP, IP_TTL, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "mDNS-IPv4: Failed to set IP_TTL: %m");
|
||||
log_error_errno(r, "mDNS-IPv4: Failed to set IP_TTL: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
r = setsockopt(m->mdns_ipv4_fd, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->mdns_ipv4_fd, IPPROTO_IP, IP_MULTICAST_TTL, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "mDNS-IPv4: Failed to set IP_MULTICAST_TTL: %m");
|
||||
log_error_errno(r, "mDNS-IPv4: Failed to set IP_MULTICAST_TTL: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -382,9 +381,9 @@ int manager_mdns_ipv4_fd(Manager *m) {
|
|||
}
|
||||
|
||||
/* Disable Don't-Fragment bit in the IP header */
|
||||
r = setsockopt(m->mdns_ipv4_fd, IPPROTO_IP, IP_MTU_DISCOVER, &pmtu, sizeof(pmtu));
|
||||
r = setsockopt_int(m->mdns_ipv4_fd, IPPROTO_IP, IP_MTU_DISCOVER, IP_PMTUDISC_DONT);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "mDNS-IPv4: Failed to set IP_MTU_DISCOVER: %m");
|
||||
log_error_errno(r, "mDNS-IPv4: Failed to set IP_MTU_DISCOVER: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
@ -436,7 +435,6 @@ int manager_mdns_ipv6_fd(Manager *m) {
|
|||
.in6.sin6_family = AF_INET6,
|
||||
.in6.sin6_port = htobe16(MDNS_PORT),
|
||||
};
|
||||
static const int ttl = 255;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -448,16 +446,16 @@ int manager_mdns_ipv6_fd(Manager *m) {
|
|||
if (m->mdns_ipv6_fd < 0)
|
||||
return log_error_errno(errno, "mDNS-IPv6: Failed to create socket: %m");
|
||||
|
||||
r = setsockopt(m->mdns_ipv6_fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->mdns_ipv6_fd, IPPROTO_IPV6, IPV6_UNICAST_HOPS, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "mDNS-IPv6: Failed to set IPV6_UNICAST_HOPS: %m");
|
||||
log_error_errno(r, "mDNS-IPv6: Failed to set IPV6_UNICAST_HOPS: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
/* RFC 4795, section 2.5 recommends setting the TTL of UDP packets to 255. */
|
||||
r = setsockopt(m->mdns_ipv6_fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, &ttl, sizeof(ttl));
|
||||
r = setsockopt_int(m->mdns_ipv6_fd, IPPROTO_IPV6, IPV6_MULTICAST_HOPS, 255);
|
||||
if (r < 0) {
|
||||
r = log_error_errno(errno, "mDNS-IPv6: Failed to set IPV6_MULTICAST_HOPS: %m");
|
||||
log_error_errno(r, "mDNS-IPv6: Failed to set IPV6_MULTICAST_HOPS: %m");
|
||||
goto fail;
|
||||
}
|
||||
|
||||
|
|
|
@ -629,7 +629,6 @@ static int manager_receive_response(sd_event_source *source, int fd, uint32_t re
|
|||
|
||||
static int manager_listen_setup(Manager *m) {
|
||||
union sockaddr_union addr = {};
|
||||
static const int tos = IPTOS_LOWDELAY;
|
||||
int r;
|
||||
|
||||
assert(m);
|
||||
|
@ -654,7 +653,7 @@ static int manager_listen_setup(Manager *m) {
|
|||
if (r < 0)
|
||||
return r;
|
||||
|
||||
(void) setsockopt(m->server_socket, IPPROTO_IP, IP_TOS, &tos, sizeof(tos));
|
||||
(void) setsockopt_int(m->server_socket, IPPROTO_IP, IP_TOS, IPTOS_LOWDELAY);
|
||||
|
||||
return sd_event_add_io(m->event, &m->event_receive, m->server_socket, EPOLLIN, manager_receive_response, m);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue