summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFederico G. Schwindt <fgsch@cvs.openbsd.org>2001-12-27 22:49:36 +0000
committerFederico G. Schwindt <fgsch@cvs.openbsd.org>2001-12-27 22:49:36 +0000
commit7b8c2ecb7ba38a4641f8b18228b1e9ba6c27dd0e (patch)
tree04ec886fcec92cdf8c42114cfd6b05e20b80f384
parent998608bddb5060430170cf30c9563b44654230ca (diff)
makes a new accept() socket have the nonblock behavior.
slightly modified version from the original diff by theo, based on comments by niels@ and deraadt@; both ok'ed.
-rw-r--r--sys/kern/uipc_syscalls.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/sys/kern/uipc_syscalls.c b/sys/kern/uipc_syscalls.c
index 8256c752cd6..e80c519f3b8 100644
--- a/sys/kern/uipc_syscalls.c
+++ b/sys/kern/uipc_syscalls.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uipc_syscalls.c,v 1.46 2001/12/02 18:07:32 provos Exp $ */
+/* $OpenBSD: uipc_syscalls.c,v 1.47 2001/12/27 22:49:35 fgsch Exp $ */
/* $NetBSD: uipc_syscalls.c,v 1.19 1996/02/09 19:00:48 christos Exp $ */
/*
@@ -159,6 +159,7 @@ sys_accept(p, v, retval)
socklen_t namelen;
int error, s, tmpfd;
struct socket *head, *so;
+ int nflag;
if (SCARG(uap, name) && (error = copyin((caddr_t)SCARG(uap, anamelen),
(caddr_t)&namelen, sizeof (namelen))))
@@ -205,6 +206,9 @@ sys_accept(p, v, retval)
if (soqremque(so, 1) == 0)
panic("accept");
+ /* Take note if socket was non-blocking. */
+ nflag = (fp->f_flag & FNONBLOCK);
+
if ((error = falloc(p, &fp, &tmpfd)) != 0) {
/*
* Probably ran out of file descriptors. Put the
@@ -226,7 +230,7 @@ sys_accept(p, v, retval)
KNOTE(&head->so_rcv.sb_sel.si_note, 0);
fp->f_type = DTYPE_SOCKET;
- fp->f_flag = FREAD|FWRITE;
+ fp->f_flag = FREAD | FWRITE | nflag;
fp->f_ops = &socketops;
fp->f_data = (caddr_t)so;
nam = m_get(M_WAIT, MT_SONAME);