summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>2001-03-03 21:19:42 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>2001-03-03 21:19:42 +0000
commit37ee72595faa2a5ed589ea833561fe9f79c5829a (patch)
treebfca690ae64ee1f67b9967fba6720b782450b506
parentd934091efc7338ace8fe6aa8e39777e5aa6cb2b9 (diff)
Dynamically allocate read_wait and its copies. Since maxfd is
baed on resource limits it is often (usually?) larger than FD_SETSIZE.
-rw-r--r--usr.bin/ssh/ssh-keyscan.c29
1 files changed, 20 insertions, 9 deletions
diff --git a/usr.bin/ssh/ssh-keyscan.c b/usr.bin/ssh/ssh-keyscan.c
index b386f1b000b..f049afe2f7e 100644
--- a/usr.bin/ssh/ssh-keyscan.c
+++ b/usr.bin/ssh/ssh-keyscan.c
@@ -8,7 +8,7 @@
*/
#include "includes.h"
-RCSID("$OpenBSD: ssh-keyscan.c,v 1.18 2001/03/03 06:53:12 deraadt Exp $");
+RCSID("$OpenBSD: ssh-keyscan.c,v 1.19 2001/03/03 21:19:41 millert Exp $");
#include <sys/queue.h>
#include <errno.h>
@@ -37,7 +37,8 @@ int maxfd;
#define MAXCON (maxfd - 10)
extern char *__progname;
-fd_set read_wait;
+fd_set *read_wait;
+size_t read_wait_size;
int ncon;
/*
@@ -341,7 +342,7 @@ conalloc(char *iname, char *oname)
gettimeofday(&fdcon[s].c_tv, NULL);
fdcon[s].c_tv.tv_sec += timeout;
TAILQ_INSERT_TAIL(&tq, &fdcon[s], c_link);
- FD_SET(s, &read_wait);
+ FD_SET(s, read_wait);
ncon++;
return (s);
}
@@ -358,7 +359,7 @@ confree(int s)
xfree(fdcon[s].c_data);
fdcon[s].c_status = CS_UNUSED;
TAILQ_REMOVE(&tq, &fdcon[s], c_link);
- FD_CLR(s, &read_wait);
+ FD_CLR(s, read_wait);
ncon--;
}
@@ -461,7 +462,7 @@ conread(int s)
void
conloop(void)
{
- fd_set r, e;
+ fd_set *r, *e;
struct timeval seltime, now;
int i;
con *c;
@@ -481,18 +482,24 @@ conloop(void)
} else
seltime.tv_sec = seltime.tv_usec = 0;
- r = e = read_wait;
- while (select(maxfd, &r, NULL, &e, &seltime) == -1 &&
+ r = xmalloc(read_wait_size);
+ memcpy(r, read_wait, read_wait_size);
+ e = xmalloc(read_wait_size);
+ memcpy(e, read_wait, read_wait_size);
+
+ while (select(maxfd, r, NULL, e, &seltime) == -1 &&
(errno == EAGAIN || errno == EINTR))
;
for (i = 0; i < maxfd; i++) {
- if (FD_ISSET(i, &e)) {
+ if (FD_ISSET(i, e)) {
error("%s: exception!", fdcon[i].c_name);
confree(i);
- } else if (FD_ISSET(i, &r))
+ } else if (FD_ISSET(i, r))
conread(i);
}
+ xfree(r);
+ xfree(e);
c = tq.tqh_first;
while (c && (c->c_tv.tv_sec < now.tv_sec ||
@@ -591,6 +598,10 @@ main(int argc, char **argv)
fdcon = xmalloc(maxfd * sizeof(con));
memset(fdcon, 0, maxfd * sizeof(con));
+ read_wait_size = howmany(maxfd, NFDBITS) * sizeof(fd_mask);
+ read_wait = xmalloc(read_wait_size);
+ memset(read_wait, 0, read_wait_size);
+
do {
while (ncon < MAXCON) {
char *name;