Skip to content

Commit

Permalink
Make new poll stuff work on win32 (and still be safe on unix)
Browse files Browse the repository at this point in the history
  • Loading branch information
wez committed Sep 17, 2004
1 parent 99e290f commit ff4e970
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 19 deletions.
25 changes: 7 additions & 18 deletions main/network.c
Original file line number Diff line number Diff line change
Expand Up @@ -1047,7 +1047,7 @@ PHPAPI int php_poll2(php_pollfd *ufds, unsigned int nfds, int timeout)
php_socket_t max_fd = SOCK_ERR;
unsigned int i, n;
struct timeval tv;

/* check the highest numbered descriptor */
for (i = 0; i < nfds; i++) {
if (ufds[i].fd > max_fd)
Expand All @@ -1061,50 +1061,39 @@ PHPAPI int php_poll2(php_pollfd *ufds, unsigned int nfds, int timeout)
FD_ZERO(&eset);

for (i = 0; i < nfds; i++) {
if (ufds[i].fd >= FD_SETSIZE) {
/* unsafe to set */
ufds[i].revents = POLLNVAL;
continue;
}
if (ufds[i].events & PHP_POLLREADABLE) {
FD_SET(ufds[i].fd, &rset);
PHP_SAFE_FD_SET(ufds[i].fd, &rset);
}
if (ufds[i].events & POLLOUT) {
FD_SET(ufds[i].fd, &wset);
PHP_SAFE_FD_SET(ufds[i].fd, &wset);
}
if (ufds[i].events & POLLPRI) {
FD_SET(ufds[i].fd, &eset);
PHP_SAFE_FD_SET(ufds[i].fd, &eset);
}
}

if (timeout >= 0) {
tv.tv_sec = timeout / 1000;
tv.tv_usec = (timeout - (tv.tv_sec * 1000)) * 1000;
}

n = select(max_fd + 1, &rset, &wset, &eset, timeout >= 0 ? &tv : NULL);

if (n >= 0) {
for (i = 0; i < nfds; i++) {
if (ufds[i].fd >= FD_SETSIZE) {
continue;
}

ufds[i].revents = 0;

if (FD_ISSET(ufds[i].fd, &rset)) {
if (PHP_SAFE_FD_ISSET(ufds[i].fd, &rset)) {
/* could be POLLERR or POLLHUP but can't tell without probing */
ufds[i].revents |= POLLIN;
}
if (FD_ISSET(ufds[i].fd, &wset)) {
if (PHP_SAFE_FD_ISSET(ufds[i].fd, &wset)) {
ufds[i].revents |= POLLOUT;
}
if (FD_ISSET(ufds[i].fd, &eset)) {
if (PHP_SAFE_FD_ISSET(ufds[i].fd, &eset)) {
ufds[i].revents |= POLLPRI;
}
}
}

return n;
}

Expand Down
3 changes: 3 additions & 0 deletions main/streams/xp_socket.c
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,9 @@ static void php_sock_stream_wait_for_data(php_stream *stream, php_netstream_data

if (retval >= 0)
break;

if (php_socket_errno() != EINTR)
break;
}
}

Expand Down
2 changes: 1 addition & 1 deletion win32/build/config.w32
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@ AC_DEFINE('HAVE_IPV6', main_network_has_ipv6);
/* this allows up to 256 sockets to be select()ed in a single
* call to select(), instead of the usual 64 */
ARG_ENABLE('fd-setsize', "Set maximum number of sockets for select(2)", "256");
AC_DEFINE('FD_SETSIZE', PHP_FD_SETSIZE);
ADD_FLAG("CFLAGS", "/D FD_SETSIZE=" + parseInt(PHP_FD_SETSIZE));

ARG_ENABLE("memory-limit", "Enable memory limit checking code", "no");

Expand Down

0 comments on commit ff4e970

Please sign in to comment.