facd1f65cb
wiz?
209 lines
5.8 KiB
Groff
209 lines
5.8 KiB
Groff
.\" $NetBSD: fstrans.9,v 1.1 2007/01/21 15:42:36 hannken Exp $
|
|
.\"
|
|
.\" Copyright (c) 2007 The NetBSD Foundation, Inc.
|
|
.\" All rights reserved.
|
|
.\"
|
|
.\" This code is derived from software contributed to The NetBSD Foundation
|
|
.\" by Juergen Hannken-Illjes.
|
|
.\"
|
|
.\" Redistribution and use in source and binary forms, with or without
|
|
.\" modification, are permitted provided that the following conditions
|
|
.\" are met:
|
|
.\" 1. Redistributions of source code must retain the above copyright
|
|
.\" notice, this list of conditions and the following disclaimer.
|
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
|
.\" notice, this list of conditions and the following disclaimer in the
|
|
.\" documentation and/or other materials provided with the distribution.
|
|
.\" 3. All advertising materials mentioning features or use of this software
|
|
.\" must display the following acknowledgement:
|
|
.\" This product includes software developed by the NetBSD
|
|
.\" Foundation, Inc. and its contributors.
|
|
.\" 4. Neither the name of The NetBSD Foundation nor the names of its
|
|
.\" contributors may be used to endorse or promote products derived
|
|
.\" from this software without specific prior written permission.
|
|
.\"
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
|
|
.\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
.\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
.\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
|
|
.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
.\" POSSIBILITY OF SUCH DAMAGE.
|
|
.\"
|
|
.Dd January 21, 2007
|
|
.Dt FSTRANS 9
|
|
.Os
|
|
.Sh NAME
|
|
.Nm fstrans ,
|
|
.Nm fstrans_setstate ,
|
|
.Nm fstrans_getstate ,
|
|
.Nm fstrans_start ,
|
|
.Nm fstrans_start_nowait ,
|
|
.Nm fstrans_done ,
|
|
.Nm fstrans_is_owner
|
|
.Nd file system suspension helper subsystem
|
|
.Sh SYNOPSIS
|
|
.In sys/mount.h
|
|
.In sys/fstrans.h
|
|
.Ft int
|
|
.Fn fstrans_setstate "struct mount *" "enum fstrans_state"
|
|
.Ft "enum fstrans_state"
|
|
.Fn fstrans_getstate "struct mount *"
|
|
.Ft int
|
|
.Fn fstrans_start "struct mount *" "enum fstrans_lock_type"
|
|
.Ft int
|
|
.Fn fstrans_start_nowait "struct mount *" "enum fstrans_lock_type"
|
|
.Ft void
|
|
.Fn fstrans_done "struct mount *"
|
|
.Ft int
|
|
.Fn fstrans_is_owner "struct mount *"
|
|
.Sh DESCRIPTION
|
|
The
|
|
.Nm
|
|
subsystem is a set of operations to assist file system suspension.
|
|
These operations must not be used outside of file systems.
|
|
.Pp
|
|
File systems supporting this subsystem must set the flag
|
|
.Dv IMNT_HAS_TRANS
|
|
in
|
|
.Dv "mnt_iflag" .
|
|
.Pp
|
|
.Em To use this subsystem the kernel option NEWVNGATE must be set .
|
|
.Pp
|
|
File systems are always in one of these states:
|
|
.Bl -tag -offset indent -width fstrans_suspending -compact
|
|
.It Dv fstrans_normal
|
|
normal operations.
|
|
.It Dv fstrans_suspending
|
|
preparing a suspension.
|
|
.It Dv fstrans_suspended
|
|
suspended.
|
|
.El
|
|
This state is represented by
|
|
.Vt "enum fstrans_state" .
|
|
.Bl -tag -width compact
|
|
.It Fn fstrans_getstate "mp"
|
|
returns the current state of the file system
|
|
.Fa mp .
|
|
.Pp
|
|
.It Fn fstrans_setstate "mp" "new_state"
|
|
changes the state of the file system
|
|
.Fa mp
|
|
to
|
|
.Fa new_state .
|
|
.El
|
|
.Pp
|
|
All file system operations use a
|
|
.Em "fstrans lock" .
|
|
This lock is recursive.
|
|
A thread already owning a lock will always get another lock.
|
|
The lock has two variants:
|
|
.Bl -tag -offset indent -width fstrans_shared -compact
|
|
.It Dv fstrans_shared
|
|
this lock will be granted if the file system is in state
|
|
.Dv fstrans_normal .
|
|
.It Dv fstrans_lazy
|
|
this lock will be granted if the file system is in state
|
|
.Dv fstrans_normal
|
|
or
|
|
.Dv fstrans_suspending .
|
|
It needs special care because operations using this variant will not block
|
|
while the file system prepares suspension.
|
|
.El
|
|
The lock variant is represented by
|
|
.Vt "enum fstrans_lock_type" .
|
|
.Bl -tag -width compact
|
|
.It Fn fstrans_start "mp" "lock_type"
|
|
sets a lock of type
|
|
.Fa lock_type
|
|
on the file system
|
|
.Fa mp .
|
|
.It Fn fstrans_start_nowait "mp" "lock_type"
|
|
will not wait for a state change of the file system when attempting to
|
|
aquire the lock.
|
|
The thread may still sleep while attempting to aquire the lock.
|
|
.It Fn fstrans_done "mp"
|
|
releases a lock on the file system
|
|
.Fa mp .
|
|
.It Fn fstrans_is_owner "mp"
|
|
returns
|
|
.Dv TRUE
|
|
if this thread is currently suspending the file system
|
|
.Fa mp .
|
|
.El
|
|
.Sh RETURN VALUES
|
|
The functions
|
|
.Fn fstrans_setstate ,
|
|
.Fn fstrans_start ,
|
|
and
|
|
.Fn fstrans_start_nowait
|
|
return zero on success and an error value on failure.
|
|
.Sh EXAMPLES
|
|
The following is an example of a file system suspend operation.
|
|
.Bd -literal
|
|
int
|
|
xxx_suspendctl(struct mount *mp, int cmd)
|
|
{
|
|
int error;
|
|
|
|
switch (cmd) {
|
|
case SUSPEND_SUSPEND:
|
|
error = fstrans_setstate(mp, fstrans_suspending);
|
|
if (error != 0)
|
|
return error;
|
|
|
|
/* Sync file system state to disk. */
|
|
|
|
return fstrans_setstate(mp, fstrans_suspended);
|
|
|
|
case SUSPEND_RESUME:
|
|
return fstrans_setstate(mp, fstrans_normal);
|
|
|
|
default:
|
|
return EINVAL;
|
|
}
|
|
}
|
|
.Ed
|
|
.Pp
|
|
This is an example of a file system operation.
|
|
.Bd -literal
|
|
int
|
|
xxx_create(void *v)
|
|
{
|
|
struct vop_create_args *ap = v;
|
|
struct mount *mp = ap->a_dvp->v_mount;
|
|
int error;
|
|
|
|
if ((error = fstrans_start(mp, fstrans_shared)) != 0)
|
|
return error;
|
|
|
|
/* Actually create the node. */
|
|
|
|
fstrans_done(mp);
|
|
|
|
return 0;
|
|
}
|
|
.Ed
|
|
.Sh SEE ALSO
|
|
.Xr vfs_resume 9 ,
|
|
.Xr vfs_suspend 9
|
|
.Sh CODE REFERENCES
|
|
The actual code implementing this subsystem can be found in the file
|
|
.Pa sys/kern/vfs_trans.c .
|
|
.Sh HISTORY
|
|
The
|
|
.Nm
|
|
subsystem appeared in
|
|
.Nx 5.0 .
|
|
.Sh AUTHORS
|
|
The
|
|
.Nm
|
|
subsystem was written by
|
|
.if t .An J\(:urgen Hannken-Illjes
|
|
.if n .An Juergen Hannken-Illjes
|
|
.Aq hannken@NetBSD.org .
|