Source-Changes-HG archive

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

[src/trunk]: src Bring back three state file system suspension:



details:   https://anonhg.NetBSD.org/src/rev/a677740d3242
branches:  trunk
changeset: 433799:a677740d3242
user:      hannken <hannken%NetBSD.org@localhost>
date:      Fri Oct 05 09:51:55 2018 +0000

description:
Bring back three state file system suspension:

  NORMAL -> SUSPENDING -> SUSPENDED

and add operation fstrans_start_lazy() that only blocks while SUSPENDED.

Change vndthread() support operation handle_with_rdwr() to bracket
its file system operations by fstrans_start_lazy() and fstrans_done().

PR kern/53624 (dom0 freeze on domU exit)

diffstat:

 distrib/sets/lists/comp/mi       |   5 ++++-
 share/man/man9/Makefile          |   3 ++-
 share/man/man9/fstrans.9         |  37 ++++++++++++++++++++++++++++++++++---
 sys/dev/vnd.c                    |  10 ++++++++--
 sys/kern/vfs_trans.c             |  22 ++++++++++++++++++++--
 sys/miscfs/genfs/genfs_vfsops.c  |   7 +++++--
 sys/rump/librump/rumpkern/emul.c |  13 +++++++++++--
 sys/sys/fstrans.h                |   6 ++++--
 8 files changed, 88 insertions(+), 15 deletions(-)

diffs (truncated from 355 to 300 lines):

diff -r 404076a5b8a2 -r a677740d3242 distrib/sets/lists/comp/mi
--- a/distrib/sets/lists/comp/mi        Fri Oct 05 09:49:23 2018 +0000
+++ b/distrib/sets/lists/comp/mi        Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: mi,v 1.2232 2018/09/26 12:59:37 rin Exp $
+#      $NetBSD: mi,v 1.2233 2018/10/05 09:51:55 hannken Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 ./etc/mtree/set.comp                           comp-sys-root
@@ -10988,6 +10988,7 @@
 ./usr/share/man/cat9/fstrans_is_owner.0                comp-sys-catman         .cat
 ./usr/share/man/cat9/fstrans_setstate.0                comp-sys-catman         .cat
 ./usr/share/man/cat9/fstrans_start.0           comp-sys-catman         .cat
+./usr/share/man/cat9/fstrans_start_lazy.0      comp-sys-catman         .cat
 ./usr/share/man/cat9/fstrans_start_nowait.0    comp-sys-catman         .cat
 ./usr/share/man/cat9/fubyte.0                  comp-sys-catman         .cat
 ./usr/share/man/cat9/fuibyte.0                 comp-sys-catman         .cat
@@ -18801,6 +18802,7 @@
 ./usr/share/man/html9/fstrans_is_owner.html    comp-sys-htmlman        html
 ./usr/share/man/html9/fstrans_setstate.html    comp-sys-htmlman        html
 ./usr/share/man/html9/fstrans_start.html       comp-sys-htmlman        html
+./usr/share/man/html9/fstrans_start_lazy.html  comp-sys-htmlman        html
 ./usr/share/man/html9/fstrans_start_nowait.html comp-sys-htmlman       html
 ./usr/share/man/html9/fubyte.html              comp-sys-htmlman        html
 ./usr/share/man/html9/fuibyte.html             comp-sys-htmlman        html
@@ -26760,6 +26762,7 @@
 ./usr/share/man/man9/fstrans_is_owner.9                comp-sys-man            .man
 ./usr/share/man/man9/fstrans_setstate.9                comp-sys-man            .man
 ./usr/share/man/man9/fstrans_start.9           comp-sys-man            .man
+./usr/share/man/man9/fstrans_start_lazy.9      comp-sys-man            .man
 ./usr/share/man/man9/fstrans_start_nowait.9    comp-sys-man            .man
 ./usr/share/man/man9/fubyte.9                  comp-sys-man            .man
 ./usr/share/man/man9/fuibyte.9                 comp-sys-man            .man
diff -r 404076a5b8a2 -r a677740d3242 share/man/man9/Makefile
--- a/share/man/man9/Makefile   Fri Oct 05 09:49:23 2018 +0000
+++ b/share/man/man9/Makefile   Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-#       $NetBSD: Makefile,v 1.430 2018/09/20 06:54:36 rin Exp $
+#       $NetBSD: Makefile,v 1.431 2018/10/05 09:51:55 hannken Exp $
 
 #      Makefile for section 9 (kernel function and variable) manual pages.
 
@@ -357,6 +357,7 @@
        fstrans.9 fstrans_getstate.9 \
        fstrans.9 fstrans_setstate.9 \
        fstrans.9 fstrans_start.9 \
+       fstrans.9 fstrans_start_lazy.9 \
        fstrans.9 fstrans_start_nowait.9 \
        fstrans.9 fscow_establish.9 \
        fstrans.9 fscow_disestablish.9 \
diff -r 404076a5b8a2 -r a677740d3242 share/man/man9/fstrans.9
--- a/share/man/man9/fstrans.9  Fri Oct 05 09:49:23 2018 +0000
+++ b/share/man/man9/fstrans.9  Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-.\"     $NetBSD: fstrans.9,v 1.26 2017/07/03 21:28:48 wiz Exp $
+.\"     $NetBSD: fstrans.9,v 1.27 2018/10/05 09:51:55 hannken Exp $
 .\"
 .\" Copyright (c) 2007 The NetBSD Foundation, Inc.
 .\" All rights reserved.
@@ -27,7 +27,7 @@
 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 .\" POSSIBILITY OF SUCH DAMAGE.
 .\"
-.Dd June 4, 2017
+.Dd October 4, 2018
 .Dt FSTRANS 9
 .Os
 .Sh NAME
@@ -36,6 +36,7 @@
 .Nm fstrans_getstate ,
 .Nm fstrans_start ,
 .Nm fstrans_start_nowait ,
+.Nm fstrans_start_lazy ,
 .Nm fstrans_done ,
 .Nm fstrans_is_owner ,
 .Nm fscow_establish ,
@@ -50,6 +51,8 @@
 .Ft int
 .Fn fstrans_start_nowait "struct mount *mp"
 .Ft void
+.Fn fstrans_start_lazy "struct mount *mp"
+.Ft void
 .Fn fstrans_done "struct mount *mp"
 .Ft int
 .Fn fstrans_setstate "struct mount *mp" "enum fstrans_state new_state"
@@ -81,6 +84,15 @@
 transaction, which is blocked by suspending the file system and while
 it is suspended.
 .Pp
+Operations needed while suspending the file system  must be bracketed by
+.Fn fstrans_start_lazy
+and
+.Fn fstrans_done
+in a
+.Em lazy
+transaction, which is allowed while suspending the file system, but
+blocked while the file system is suspended.
+.Pp
 Transactions are per-thread and nestable: if a thread is already in a
 transaction, it can enter another transaction without blocking.
 Each
@@ -97,6 +109,10 @@
 .Bl -dash
 .It
 enter the
+.Dv FSTRANS_SUSPENDING
+to suspend all normal operations but allow lazy transactions,
+.It
+enter the
 .Dv FSTRANS_SUSPENDED
 state to suspend all operations, and
 .It
@@ -149,6 +165,12 @@
 immediately if transactions are blocked in its current state.
 .Pp
 May sleep nevertheless on internal locks.
+.It Fn fstrans_start_lazy "mp"
+Like
+.Fn fstrans_start ,
+but will not block while suspending.
+.Pp
+May sleep.
 .It Fn fstrans_done "mp"
 End the current transaction on
 .Fa mp .
@@ -165,9 +187,15 @@
 and wait for all transactions not allowed in
 .Fa new_state
 to complete.
-.Bl -tag -width FSTRANS_SUSPENDED
+.Bl -tag -width FSTRANS_SUSPENDING
 .It Dv FSTRANS_NORMAL
 Allow all transactions.
+.It Dv FSTRANS_SUSPENDING
+Block
+.Dv FSTRANS_SHARED
+transactions but allow
+.Dv FSTRANS_LAZY
+transactions.
 .It Dv FSTRANS_SUSPENDED
 Block all transactions.
 .El
@@ -244,6 +272,9 @@
 
        switch (cmd) {
        case SUSPEND_SUSPEND:
+               error = fstrans_setstate(mp, FSTRANS_SUSPENDING);
+               if (error)
+                       return error;
                return fstrans_setstate(mp, FSTRANS_SUSPENDED);
 
        case SUSPEND_RESUME:
diff -r 404076a5b8a2 -r a677740d3242 sys/dev/vnd.c
--- a/sys/dev/vnd.c     Fri Oct 05 09:49:23 2018 +0000
+++ b/sys/dev/vnd.c     Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vnd.c,v 1.265 2018/09/20 07:18:38 mlelstv Exp $        */
+/*     $NetBSD: vnd.c,v 1.266 2018/10/05 09:51:55 hannken Exp $        */
 
 /*-
  * Copyright (c) 1996, 1997, 1998, 2008 The NetBSD Foundation, Inc.
@@ -91,7 +91,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vnd.c,v 1.265 2018/09/20 07:18:38 mlelstv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vnd.c,v 1.266 2018/10/05 09:51:55 hannken Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_vnd.h"
@@ -114,6 +114,7 @@
 #include <sys/stat.h>
 #include <sys/mount.h>
 #include <sys/vnode.h>
+#include <sys/fstrans.h>
 #include <sys/file.h>
 #include <sys/uio.h>
 #include <sys/conf.h>
@@ -802,6 +803,9 @@
                    bp->b_bcount);
 #endif
 
+       /* Make sure the request succeeds while suspending this fs. */
+       fstrans_start_lazy(vp->v_mount);
+
        /* Issue the read or write operation. */
        bp->b_error =
            vn_rdwr(doread ? UIO_READ : UIO_WRITE,
@@ -813,6 +817,8 @@
        (void) VOP_PUTPAGES(vp, 0, 0,
            PGO_ALLPAGES | PGO_CLEANIT | PGO_FREE | PGO_SYNCIO);
 
+       fstrans_done(vp->v_mount);
+
        /* We need to increase the number of outputs on the vnode if
         * there was any write to it. */
        if (!doread) {
diff -r 404076a5b8a2 -r a677740d3242 sys/kern/vfs_trans.c
--- a/sys/kern/vfs_trans.c      Fri Oct 05 09:49:23 2018 +0000
+++ b/sys/kern/vfs_trans.c      Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vfs_trans.c,v 1.50 2018/10/05 01:25:38 manu Exp $      */
+/*     $NetBSD: vfs_trans.c,v 1.51 2018/10/05 09:51:55 hannken Exp $   */
 
 /*-
  * Copyright (c) 2007 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_trans.c,v 1.50 2018/10/05 01:25:38 manu Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_trans.c,v 1.51 2018/10/05 09:51:55 hannken Exp $");
 
 /*
  * File system transaction operations.
@@ -54,6 +54,7 @@
 #include <miscfs/specfs/specdev.h>
 
 enum fstrans_lock_type {
+       FSTRANS_LAZY,                   /* Granted while not suspended */
        FSTRANS_SHARED,                 /* Granted while not suspending */
        FSTRANS_EXCL                    /* Internal: exclusive lock */
 };
@@ -342,6 +343,8 @@
                return true;
        if (type == FSTRANS_EXCL)
                return true;
+       if  (state == FSTRANS_SUSPENDING && type == FSTRANS_LAZY)
+               return true;
 
        return false;
 }
@@ -422,6 +425,15 @@
        return _fstrans_start(mp, FSTRANS_SHARED, 0);
 }
 
+void
+fstrans_start_lazy(struct mount *mp)
+{
+       int error __diagused;
+
+       error = _fstrans_start(mp, FSTRANS_LAZY, 1);
+       KASSERT(error == 0);
+}
+
 /*
  * Finish a transaction.
  */
@@ -849,6 +861,9 @@
                        printf(" -");
                } else {
                        switch (fli->fli_lock_type) {
+                       case FSTRANS_LAZY:
+                               printf(" lazy");
+                               break;
                        case FSTRANS_SHARED:
                                printf(" shared");
                                break;
@@ -883,6 +898,9 @@
        case FSTRANS_NORMAL:
                printf("state normal\n");
                break;
+       case FSTRANS_SUSPENDING:
+               printf("state suspending\n");
+               break;
        case FSTRANS_SUSPENDED:
                printf("state suspended\n");
                break;
diff -r 404076a5b8a2 -r a677740d3242 sys/miscfs/genfs/genfs_vfsops.c
--- a/sys/miscfs/genfs/genfs_vfsops.c   Fri Oct 05 09:49:23 2018 +0000
+++ b/sys/miscfs/genfs/genfs_vfsops.c   Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: genfs_vfsops.c,v 1.7 2017/05/24 09:53:55 hannken Exp $ */
+/*     $NetBSD: genfs_vfsops.c,v 1.8 2018/10/05 09:51:55 hannken Exp $ */
 
 /*-
  * Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: genfs_vfsops.c,v 1.7 2017/05/24 09:53:55 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: genfs_vfsops.c,v 1.8 2018/10/05 09:51:55 hannken Exp $");
 
 #include <sys/types.h>
 #include <sys/mount.h>
@@ -83,6 +83,9 @@
 
        switch (cmd) {
        case SUSPEND_SUSPEND:
+               error = fstrans_setstate(mp, FSTRANS_SUSPENDING);
+               if (error)
+                       return error;
                error = fstrans_setstate(mp, FSTRANS_SUSPENDED);
                if (error == 0) {
                        if ((mp->mnt_iflag & IMNT_GONE) != 0)
diff -r 404076a5b8a2 -r a677740d3242 sys/rump/librump/rumpkern/emul.c
--- a/sys/rump/librump/rumpkern/emul.c  Fri Oct 05 09:49:23 2018 +0000
+++ b/sys/rump/librump/rumpkern/emul.c  Fri Oct 05 09:51:55 2018 +0000
@@ -1,4 +1,4 @@



Home | Main Index | Thread Index | Old Index