Source-Changes-HG archive

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

[src/trunk]: src/sys Add vfs_trybusy() and mountlist_iterator_trynext() and u...



details:   https://anonhg.NetBSD.org/src/rev/e3bc4036316c
branches:  trunk
changeset: 353008:e3bc4036316c
user:      hannken <hannken%NetBSD.org@localhost>
date:      Mon Apr 17 08:34:27 2017 +0000

description:
Add vfs_trybusy() and mountlist_iterator_trynext() and use it for the syncer.

diffstat:

 sys/kern/vfs_mount.c |  53 ++++++++++++++++++++++++++++++++++++++++++++-------
 sys/kern/vfs_subr.c  |   6 ++--
 sys/sys/mount.h      |   4 ++-
 3 files changed, 51 insertions(+), 12 deletions(-)

diffs (161 lines):

diff -r c1aaae609bb4 -r e3bc4036316c sys/kern/vfs_mount.c
--- a/sys/kern/vfs_mount.c      Mon Apr 17 08:33:40 2017 +0000
+++ b/sys/kern/vfs_mount.c      Mon Apr 17 08:34:27 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vfs_mount.c,v 1.57 2017/04/17 08:32:55 hannken Exp $   */
+/*     $NetBSD: vfs_mount.c,v 1.58 2017/04/17 08:34:27 hannken Exp $   */
 
 /*-
  * Copyright (c) 1997-2011 The NetBSD Foundation, Inc.
@@ -67,7 +67,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_mount.c,v 1.57 2017/04/17 08:32:55 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_mount.c,v 1.58 2017/04/17 08:34:27 hannken Exp $");
 
 #include <sys/param.h>
 #include <sys/kernel.h>
@@ -311,13 +311,17 @@
  * => The caller must hold a pre-existing reference to the mount.
  * => Will fail if the file system is being unmounted, or is unmounted.
  */
-int
-vfs_busy(struct mount *mp)
+static inline int
+_vfs_busy(struct mount *mp, bool wait)
 {
 
        KASSERT(mp->mnt_refcnt > 0);
 
-       mutex_enter(&mp->mnt_unmounting);
+       if (wait) {
+               mutex_enter(&mp->mnt_unmounting);
+       } else if (!mutex_tryenter(&mp->mnt_unmounting)) {
+               return EBUSY;
+       }
        if (__predict_false((mp->mnt_iflag & IMNT_GONE) != 0)) {
                mutex_exit(&mp->mnt_unmounting);
                return ENOENT;
@@ -329,6 +333,20 @@
        return 0;
 }
 
+int
+vfs_busy(struct mount *mp)
+{
+
+       return _vfs_busy(mp, true);
+}
+
+int
+vfs_trybusy(struct mount *mp)
+{
+
+       return _vfs_busy(mp, false);
+}
+
 /*
  * Unbusy a busy filesystem.
  *
@@ -1524,11 +1542,12 @@
  * Return the next mount or NULL for this iterator.
  * Mark it busy on success.
  */
-struct mount *
-mountlist_iterator_next(mount_iterator_t *mi)
+static inline struct mount *
+_mountlist_iterator_next(mount_iterator_t *mi, bool wait)
 {
        struct mountlist_entry *me, *marker = &mi->mi_entry;
        struct mount *mp;
+       int error;
 
        if (marker->me_mount != NULL) {
                vfs_unbusy(marker->me_mount);
@@ -1559,7 +1578,11 @@
                mutex_exit(&mountlist_lock);
 
                /* Try to mark this mount busy and return on success. */
-               if (vfs_busy(mp) == 0) {
+               if (wait)
+                       error = vfs_busy(mp);
+               else
+                       error = vfs_trybusy(mp);
+               if (error == 0) {
                        vfs_rele(mp);
                        marker->me_mount = mp;
                        return mp;
@@ -1569,6 +1592,20 @@
        }
 }
 
+struct mount *
+mountlist_iterator_next(mount_iterator_t *mi)
+{
+
+       return _mountlist_iterator_next(mi, true);
+}
+
+struct mount *
+mountlist_iterator_trynext(mount_iterator_t *mi)
+{
+
+       return _mountlist_iterator_next(mi, false);
+}
+
 /*
  * Attach new mount to the end of the mount list.
  */
diff -r c1aaae609bb4 -r e3bc4036316c sys/kern/vfs_subr.c
--- a/sys/kern/vfs_subr.c       Mon Apr 17 08:33:40 2017 +0000
+++ b/sys/kern/vfs_subr.c       Mon Apr 17 08:34:27 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vfs_subr.c,v 1.462 2017/04/12 10:26:33 hannken Exp $   */
+/*     $NetBSD: vfs_subr.c,v 1.463 2017/04/17 08:34:27 hannken Exp $   */
 
 /*-
  * Copyright (c) 1997, 1998, 2004, 2005, 2007, 2008 The NetBSD Foundation, Inc.
@@ -68,7 +68,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_subr.c,v 1.462 2017/04/12 10:26:33 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_subr.c,v 1.463 2017/04/17 08:34:27 hannken Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_ddb.h"
@@ -775,7 +775,7 @@
                 * Sync mounts whose dirty time has expired.
                 */
                mountlist_iterator_init(&iter);
-               while ((mp = mountlist_iterator_next(iter)) != NULL) {
+               while ((mp = mountlist_iterator_trynext(iter)) != NULL) {
                        if ((mp->mnt_iflag & IMNT_ONWORKLIST) == 0 ||
                            mp->mnt_synclist_slot != syncer_delayno) {
                                continue;
diff -r c1aaae609bb4 -r e3bc4036316c sys/sys/mount.h
--- a/sys/sys/mount.h   Mon Apr 17 08:33:40 2017 +0000
+++ b/sys/sys/mount.h   Mon Apr 17 08:34:27 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mount.h,v 1.225 2017/04/17 08:32:01 hannken Exp $      */
+/*     $NetBSD: mount.h,v 1.226 2017/04/17 08:34:27 hannken Exp $      */
 
 /*
  * Copyright (c) 1989, 1991, 1993
@@ -417,6 +417,7 @@
 bool   vfs_unmountall1(struct lwp *, bool, bool);
 bool   vfs_unmount_forceone(struct lwp *);
 int    vfs_busy(struct mount *);
+int    vfs_trybusy(struct mount *);
 int    vfs_rootmountalloc(const char *, const char *, struct mount **);
 void   vfs_unbusy(struct mount *);
 int    vfs_attach(struct vfsops *);
@@ -496,6 +497,7 @@
 void   mountlist_iterator_init(mount_iterator_t **);
 void   mountlist_iterator_destroy(mount_iterator_t *);
 struct mount *mountlist_iterator_next(mount_iterator_t *);
+struct mount *mountlist_iterator_trynext(mount_iterator_t *);
 struct mount *_mountlist_next(struct mount *);
 void   mountlist_append(struct mount *);
 void   mountlist_remove(struct mount *);



Home | Main Index | Thread Index | Old Index