Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/nfs don't allow the nfs server module to unload if it ha...



details:   https://anonhg.NetBSD.org/src/rev/ef3aa9deb057
branches:  trunk
changeset: 325234:ef3aa9deb057
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Dec 14 16:19:28 2013 +0000

description:
don't allow the nfs server module to unload if it has exported filesystems.

diffstat:

 sys/nfs/nfs_export.c |  11 +++++++++--
 sys/nfs/nfs_serv.c   |   6 ++++--
 sys/nfs/nfs_var.h    |   3 ++-
 3 files changed, 15 insertions(+), 5 deletions(-)

diffs (71 lines):

diff -r 65e4f63ab012 -r ef3aa9deb057 sys/nfs/nfs_export.c
--- a/sys/nfs/nfs_export.c      Sat Dec 14 16:03:04 2013 +0000
+++ b/sys/nfs/nfs_export.c      Sat Dec 14 16:19:28 2013 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_export.c,v 1.57 2013/11/23 14:20:46 christos Exp $ */
+/*     $NetBSD: nfs_export.c,v 1.58 2013/12/14 16:19:28 christos Exp $ */
 
 /*-
  * Copyright (c) 1997, 1998, 2004, 2005, 2008 The NetBSD Foundation, Inc.
@@ -77,7 +77,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_export.c,v 1.57 2013/11/23 14:20:46 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_export.c,v 1.58 2013/12/14 16:19:28 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -877,3 +877,10 @@
 
        rw_exit(&netexport_lock);
 }
+
+bool
+netexport_hasexports(void)
+{
+       
+       return nfs_pub.np_valid || !TAILQ_EMPTY(&netexport_list);
+}
diff -r 65e4f63ab012 -r ef3aa9deb057 sys/nfs/nfs_serv.c
--- a/sys/nfs/nfs_serv.c        Sat Dec 14 16:03:04 2013 +0000
+++ b/sys/nfs/nfs_serv.c        Sat Dec 14 16:19:28 2013 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_serv.c,v 1.166 2013/09/14 22:29:08 martin Exp $    */
+/*     $NetBSD: nfs_serv.c,v 1.167 2013/12/14 16:19:28 christos Exp $  */
 
 /*
  * Copyright (c) 1989, 1993
@@ -55,7 +55,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nfs_serv.c,v 1.166 2013/09/14 22:29:08 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nfs_serv.c,v 1.167 2013/12/14 16:19:28 christos Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -125,6 +125,8 @@
                nfs_timer_srvinit(nfsrv_timer);
                return 0;
        case MODULE_CMD_FINI:
+               if (netexport_hasexports())
+                       return EBUSY;
                error = syscall_disestablish(NULL, nfsserver_syscalls);
                if (error != 0) {
                        return error;
diff -r 65e4f63ab012 -r ef3aa9deb057 sys/nfs/nfs_var.h
--- a/sys/nfs/nfs_var.h Sat Dec 14 16:03:04 2013 +0000
+++ b/sys/nfs/nfs_var.h Sat Dec 14 16:19:28 2013 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nfs_var.h,v 1.90 2010/03/02 23:19:09 pooka Exp $       */
+/*     $NetBSD: nfs_var.h,v 1.91 2013/12/14 16:19:28 christos Exp $    */
 
 /*-
  * Copyright (c) 1996 The NetBSD Foundation, Inc.
@@ -349,4 +349,5 @@
 void netexport_rdunlock(void);
 void netexport_init(void);
 void netexport_fini(void);
+bool netexport_hasexports(void);
 #endif /* _KERNEL */



Home | Main Index | Thread Index | Old Index