Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/nfsd Don't exit if we have udp only sockets, instea...
details: https://anonhg.NetBSD.org/src/rev/13e016ad8512
branches: trunk
changeset: 347384:13e016ad8512
user: christos <christos%NetBSD.org@localhost>
date: Tue Aug 23 13:10:12 2016 +0000
description:
Don't exit if we have udp only sockets, instead wait for all the workers
to terminate.
diffstat:
usr.sbin/nfsd/nfsd.c | 23 ++++++++++++++++-------
1 files changed, 16 insertions(+), 7 deletions(-)
diffs (68 lines):
diff -r 0c2a5f008836 -r 13e016ad8512 usr.sbin/nfsd/nfsd.c
--- a/usr.sbin/nfsd/nfsd.c Tue Aug 23 11:03:52 2016 +0000
+++ b/usr.sbin/nfsd/nfsd.c Tue Aug 23 13:10:12 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nfsd.c,v 1.67 2016/08/22 16:08:51 christos Exp $ */
+/* $NetBSD: nfsd.c,v 1.68 2016/08/23 13:10:12 christos Exp $ */
/*
* Copyright (c) 1989, 1993, 1994
@@ -42,7 +42,7 @@
#if 0
static char sccsid[] = "@(#)nfsd.c 8.9 (Berkeley) 3/29/95";
#else
-__RCSID("$NetBSD: nfsd.c,v 1.67 2016/08/22 16:08:51 christos Exp $");
+__RCSID("$NetBSD: nfsd.c,v 1.68 2016/08/23 13:10:12 christos Exp $");
#endif
#endif /* not lint */
@@ -425,6 +425,7 @@
int ip6flag, ip4flag;
int s, compat;
int parent_fd = -1;
+ pthread_t *workers;
#define DEFNFSDCNT 4
nfsdcnt = DEFNFSDCNT;
@@ -517,11 +518,16 @@
tryconf(&cfg[i], i, reregister);
}
+ workers = calloc(nfsdcnt, sizeof(*workers));
+ if (workers == NULL) {
+ logit(LOG_ERR, "thread alloc %s", strerror(errno));
+ exit(1);
+ }
+
for (i = 0; i < nfsdcnt; i++) {
- pthread_t t;
int error;
- error = pthread_create(&t, NULL, worker, NULL);
+ error = pthread_create(&workers[i], NULL, worker, NULL);
if (error) {
errno = error;
logit(LOG_ERR, "pthread_create: %s", strerror(errno));
@@ -544,9 +550,6 @@
}
- if (connect_type_cnt == 0)
- exit(0);
-
pthread_setname_np(pthread_self(), "master", NULL);
if (debug == 0) {
@@ -557,6 +560,12 @@
(void)signal(SIGSYS, nonfs);
}
+ if (connect_type_cnt == 0) {
+ for (i = 0; i < nfsdcnt; i++)
+ pthread_join(workers[i], NULL);
+ exit(0);
+ }
+
/*
* Loop forever accepting connections and passing the sockets
* into the kernel for the mounts.
Home |
Main Index |
Thread Index |
Old Index