summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/libpthread/uthread/uthread_select.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/libpthread/uthread/uthread_select.c b/lib/libpthread/uthread/uthread_select.c
index 33620ffc254..b3a227b474e 100644
--- a/lib/libpthread/uthread/uthread_select.c
+++ b/lib/libpthread/uthread/uthread_select.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uthread_select.c,v 1.8 2003/10/19 22:49:11 marc Exp $ */
+/* $OpenBSD: uthread_select.c,v 1.9 2003/11/03 20:27:48 marc Exp $ */
/*
* Copyright (c) 1995-1998 John Birrell <jb@cimlogic.com.au>
* All rights reserved.
@@ -45,6 +45,11 @@
#include <pthread.h>
#include "pthread_private.h"
+/*
+ * Minimum number of poll_data entries to allocate
+ */
+#define POLLDATA_MIN 128
+
int
select(int numfds, fd_set * readfds, fd_set * writefds,
fd_set * exceptfds, struct timeval * timeout)
@@ -102,7 +107,7 @@ select(int numfds, fd_set * readfds, fd_set * writefds,
if ((curthread->poll_data.fds == NULL) ||
(curthread->poll_data.nfds < fd_count)) {
data.fds = (struct pollfd *) realloc(curthread->poll_data.fds,
- sizeof(struct pollfd) * MAX(128, fd_count));
+ sizeof(struct pollfd) * MAX(POLLDATA_MIN, fd_count));
if (data.fds == NULL) {
errno = ENOMEM;
ret = -1;
@@ -114,7 +119,7 @@ select(int numfds, fd_set * readfds, fd_set * writefds,
* currently being polled.
*/
curthread->poll_data.fds = data.fds;
- curthread->poll_data.nfds = MAX(128, fd_count);
+ curthread->poll_data.nfds = MAX(POLLDATA_MIN, fd_count);
}
}
if (ret == 0) {