2008-08-07 00:15:30 +04:00
|
|
|
#!/bin/sh
|
|
|
|
#
|
2009-02-15 21:00:16 +03:00
|
|
|
# $NetBSD: makerumpmanpages.sh,v 1.8 2009/02/15 18:00:16 pooka Exp $
|
2008-08-07 00:15:30 +04:00
|
|
|
#
|
|
|
|
|
|
|
|
IFS=' '
|
|
|
|
MANTMPL=".\\\" \$NetBSD\$"'
|
|
|
|
.\"
|
2008-08-07 00:18:19 +04:00
|
|
|
.\" WARNING: GENERATED FILE, DO NOT EDIT
|
|
|
|
.\" INSTEAD, EDIT makerumpmanpages.sh AND REGEN
|
|
|
|
.\"
|
2008-08-07 00:15:30 +04:00
|
|
|
.\" Copyright (c) 2008 Antti Kantee. All rights reserved.
|
|
|
|
.\"
|
|
|
|
.\" 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.
|
|
|
|
.\"
|
|
|
|
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR 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 AUTHOR 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.
|
|
|
|
.\"
|
2009-02-15 21:00:16 +03:00
|
|
|
.Dd February 15, 2009
|
2008-08-07 00:15:30 +04:00
|
|
|
.Dt RUMP_XXXFSXXX 8
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm rump_xxxfsxxx
|
|
|
|
.Nd mount the xxxfsxxx file system using a userspace server
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.Cd "file-system PUFFS"
|
2009-02-15 21:00:16 +03:00
|
|
|
.Cd "pseudo-device putter"
|
2008-08-07 00:15:30 +04:00
|
|
|
.Pp
|
|
|
|
.Nm
|
|
|
|
.Op options
|
|
|
|
.Ar special
|
|
|
|
.Ar node
|
|
|
|
.Sh DESCRIPTION
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility can be used to mount xxxfsxxx file systems.
|
|
|
|
It uses
|
|
|
|
.Xr rump 3
|
|
|
|
and
|
|
|
|
.Xr p2k 3
|
|
|
|
to facilitate running the file system as a server in userspace.
|
|
|
|
As opposed to
|
|
|
|
.Xr mount_xxxfsxxx 8 ,
|
|
|
|
.Nm
|
|
|
|
does not use file system code within the kernel and therefore does
|
|
|
|
not require kernel support except
|
|
|
|
.Xr puffs 4 .
|
2008-10-16 14:30:17 +04:00
|
|
|
Apart from a minor speed penalty (starting from 10% and depending
|
|
|
|
on the workload and file system in question), there is no difference
|
|
|
|
to using in-kernel code.
|
2008-08-07 00:15:30 +04:00
|
|
|
.Pp
|
2009-02-10 18:04:35 +03:00
|
|
|
In case mounting a file system image from a regular file,
|
|
|
|
.Nm
|
|
|
|
does not require the use of
|
|
|
|
.Xr vnconfig 8
|
|
|
|
unlike kernel file systems.
|
|
|
|
Instead, the image path can be directly passed as the special file path.
|
|
|
|
The exception is if the image contains a disklabel.
|
|
|
|
In this case vnconfig is required to resolve the start offset for the
|
|
|
|
correct partition within the image.
|
|
|
|
.Pp
|
2008-08-07 00:15:30 +04:00
|
|
|
It is recommended that untrusted file system images be mounted with
|
|
|
|
.Nm
|
|
|
|
instead of
|
|
|
|
.Xr mount_xxxfsxxx 8 .
|
|
|
|
Corrupt file system images commonly cause the file system
|
|
|
|
to crash the entire kernel, but with
|
|
|
|
.Nm
|
|
|
|
only the userspace server process will dump core.
|
|
|
|
.Pp
|
2009-01-12 00:15:07 +03:00
|
|
|
To use
|
|
|
|
.Nm
|
|
|
|
via
|
|
|
|
.Xr mount 8 ,
|
|
|
|
the flags
|
2009-01-12 01:02:38 +03:00
|
|
|
.Fl o Ar rump
|
2009-01-12 00:15:07 +03:00
|
|
|
and
|
2009-01-12 01:02:38 +03:00
|
|
|
.Fl t Ar xxxfsxxx
|
2009-01-12 00:15:07 +03:00
|
|
|
should be given.
|
|
|
|
Similarly,
|
|
|
|
.Nm
|
|
|
|
is run instead of
|
|
|
|
.Xr mount_xxxfsxxx 8
|
2009-01-12 01:02:38 +03:00
|
|
|
if
|
2009-01-12 00:15:07 +03:00
|
|
|
.Dq rump
|
|
|
|
is added to the options field of
|
|
|
|
.Xr fstab 5 .
|
|
|
|
.Pp
|
2008-08-07 00:15:30 +04:00
|
|
|
Please see
|
|
|
|
.Xr mount_xxxfsxxx 8
|
|
|
|
for a full description of the available command line options.
|
|
|
|
.Sh SEE ALSO
|
|
|
|
.Xr p2k 3 ,
|
|
|
|
.Xr puffs 3 ,
|
|
|
|
.Xr rump 3 ,
|
|
|
|
.Xr mount_xxxfsxxx 8
|
|
|
|
.Sh HISTORY
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility first appeared in
|
2009-02-15 21:00:16 +03:00
|
|
|
.Nx 5.0 .
|
|
|
|
It is currently considered experimental.'
|
2008-08-07 00:15:30 +04:00
|
|
|
|
|
|
|
# generate the manual pages
|
|
|
|
#
|
|
|
|
for x in rump_*
|
|
|
|
do
|
|
|
|
fs=${x#rump_}
|
|
|
|
|
|
|
|
# syspuffs is special, it has a handwritten manpage
|
|
|
|
if [ "$fs" = "syspuffs" ]
|
|
|
|
then
|
|
|
|
continue
|
|
|
|
fi
|
|
|
|
|
|
|
|
fsc=`echo $fs | tr '[:lower:]' '[:upper:]'`
|
2008-09-05 13:07:40 +04:00
|
|
|
echo ${MANTMPL} | sed "s/xxxfsxxx/$fs/g;s/XXXFSXXX/$fsc/g" > \
|
2008-08-07 00:15:30 +04:00
|
|
|
rump_${fs}/rump_${fs}.8
|
|
|
|
done
|