0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-15 02:07:59 +08:00

Problem: zmq_poller_*_fd functions do not check for invalid fd

Solution: add checks, added test cases
This commit is contained in:
sigiesec 2017-08-22 17:54:50 +02:00
parent f9af5503b4
commit 2e4fc4faf0
2 changed files with 38 additions and 5 deletions

View File

@ -1269,6 +1269,10 @@ int zmq_poller_add_fd (void *poller_, int fd_, void *user_data_, short events_)
errno = EFAULT; errno = EFAULT;
return -1; return -1;
} }
if (fd_ == zmq::retired_fd) {
errno = ENOTSOCK;
return -1;
}
return ((zmq::socket_poller_t*)poller_)->add_fd (fd_, user_data_, events_); return ((zmq::socket_poller_t*)poller_)->add_fd (fd_, user_data_, events_);
} }
@ -1301,6 +1305,10 @@ int zmq_poller_modify_fd (void *poller_, int fd_, short events_)
errno = EFAULT; errno = EFAULT;
return -1; return -1;
} }
if (fd_ == zmq::retired_fd) {
errno = ENOTSOCK;
return -1;
}
return ((zmq::socket_poller_t*)poller_)->modify_fd (fd_, events_); return ((zmq::socket_poller_t*)poller_)->modify_fd (fd_, events_);
} }
@ -1332,6 +1340,10 @@ int zmq_poller_remove_fd (void *poller_, int fd_)
errno = EFAULT; errno = EFAULT;
return -1; return -1;
} }
if (fd_ == zmq::retired_fd) {
errno = ENOTSOCK;
return -1;
}
return ((zmq::socket_poller_t*)poller_)->remove_fd (fd_); return ((zmq::socket_poller_t*)poller_)->remove_fd (fd_);
} }

View File

@ -29,6 +29,20 @@
#include "testutil.hpp" #include "testutil.hpp"
// duplicated from fd.hpp
#ifdef ZMQ_HAVE_WINDOWS
#if defined _MSC_VER &&_MSC_VER <= 1400
typedef UINT_PTR fd_t;
enum {retired_fd = (fd_t)(~0)};
#else
typedef SOCKET fd_t;
enum {retired_fd = (fd_t)INVALID_SOCKET};
#endif
#else
typedef int fd_t;
enum {retired_fd = -1};
#endif
void test_null_poller_pointers (void *ctx) void test_null_poller_pointers (void *ctx)
{ {
int rc = zmq_poller_destroy (NULL); int rc = zmq_poller_destroy (NULL);
@ -55,11 +69,7 @@ void test_null_poller_pointers (void *ctx)
rc = zmq_poller_remove (&null_poller, socket); rc = zmq_poller_remove (&null_poller, socket);
assert (rc == -1 && errno == EFAULT); assert (rc == -1 && errno == EFAULT);
#ifdef _WIN32 fd_t fd;
SOCKET fd;
#else
int fd;
#endif
size_t fd_size = sizeof fd; size_t fd_size = sizeof fd;
rc = zmq_getsockopt(socket, ZMQ_FD, &fd, &fd_size); rc = zmq_getsockopt(socket, ZMQ_FD, &fd, &fd_size);
assert (rc == 0); assert (rc == 0);
@ -97,6 +107,17 @@ void test_null_socket_pointers ()
rc = zmq_poller_remove (poller, NULL); rc = zmq_poller_remove (poller, NULL);
assert (rc == -1 && errno == ENOTSOCK); assert (rc == -1 && errno == ENOTSOCK);
fd_t null_socket_fd = retired_fd;
rc = zmq_poller_add_fd (poller, null_socket_fd, NULL, ZMQ_POLLIN);
assert (rc == -1 && errno == ENOTSOCK);
rc = zmq_poller_modify_fd (poller, null_socket_fd, ZMQ_POLLIN);
assert (rc == -1 && errno == ENOTSOCK);
rc = zmq_poller_remove_fd (poller, null_socket_fd);
assert (rc == -1 && errno == ENOTSOCK);
rc = zmq_poller_destroy (&poller); rc = zmq_poller_destroy (&poller);
assert (rc == 0); assert (rc == 0);
} }