From: Andre Date: Sun, 4 Jun 2006 19:48:34 +0000 (+0200) Subject: add some debugging to fd.c X-Git-Tag: v0.2.14~85 X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=commitdiff_plain;h=9311067b68d9412a02c041873204bcffcb1b9fea add some debugging to fd.c Detect an invalid fd if passed to para_fd_set and abort in this case. A typical "values of beta will cause dom!" candidate. --- diff --git a/fd.c b/fd.c index ef2c64ca..d1e0412d 100644 --- a/fd.c +++ b/fd.c @@ -64,7 +64,8 @@ int para_select(int n, fd_set *readfds, fd_set *writefds, err = errno; } while (ret < 0 && err == EINTR); if (ret < 0) - PARA_CRIT_LOG("select error (%s)\n", strerror(err)); + PARA_CRIT_LOG("select error: %s, max_fileno: %d\n", + strerror(err), n); return ret; } @@ -99,6 +100,10 @@ int mark_fd_nonblock(int fd) */ void para_fd_set(int fd, fd_set *fds, int *max_fileno) { + if (fd < 0 || fd >= FD_SETSIZE) { + PARA_EMERG_LOG("fatal: tried to add invalid fd %d\n", fd); + exit(EXIT_FAILURE); + } FD_SET(fd, fds); *max_fileno = PARA_MAX(*max_fileno, fd); }