mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-27 22:46:02 -05:00
[mdns] Fix select issue on FreeBSD.
As reported in issue #1654, using select to test for a (non-blocking) connection success crashes on FreeBSD when the number of opened file descriptor is higher than FDSET_SIZE. Instead of returning with an error in that case, this commit uses poll instead that's not limited to the number of opened file descriptors, preventing an out-of-bound write.
This commit is contained in:
parent
8528073003
commit
ab790c2880
@ -36,6 +36,7 @@
|
|||||||
#include <net/if.h>
|
#include <net/if.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
|
#include <poll.h>
|
||||||
|
|
||||||
#include <event2/event.h>
|
#include <event2/event.h>
|
||||||
|
|
||||||
@ -582,8 +583,7 @@ connection_test(int family, const char *address, const char *address_log, int po
|
|||||||
struct addrinfo *ai;
|
struct addrinfo *ai;
|
||||||
char strport[32];
|
char strport[32];
|
||||||
int sock;
|
int sock;
|
||||||
fd_set fdset;
|
struct pollfd fd;
|
||||||
struct timeval timeout = { MDNS_CONNECT_TEST_TIMEOUT, 0 };
|
|
||||||
socklen_t len;
|
socklen_t len;
|
||||||
int flags;
|
int flags;
|
||||||
int error;
|
int error;
|
||||||
@ -639,10 +639,11 @@ connection_test(int family, const char *address, const char *address_log, int po
|
|||||||
// the case, but FreeBSD connect() sometimes returns immediate success.
|
// the case, but FreeBSD connect() sometimes returns immediate success.
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
{
|
{
|
||||||
FD_ZERO(&fdset);
|
// Use poll here since select requires using fdset that would be overflowed in FreeBSD
|
||||||
FD_SET(sock, &fdset);
|
fd.fd = sock;
|
||||||
|
fd.events = POLLOUT;
|
||||||
|
|
||||||
ret = select(sock + 1, NULL, &fdset, NULL, &timeout);
|
ret = poll(&fd, 1, MDNS_CONNECT_TEST_TIMEOUT * 1000);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
DPRINTF(E_WARN, L_MDNS, "Connection test to %s:%d failed with select error: %s\n", address_log, port, strerror(errno));
|
DPRINTF(E_WARN, L_MDNS, "Connection test to %s:%d failed with select error: %s\n", address_log, port, strerror(errno));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user