2012-04-18 04:57:21 +04:00
|
|
|
.\" $NetBSD: puffs.3,v 1.52 2012/04/18 00:57:22 manu Exp $
|
2006-11-09 04:30:15 +03:00
|
|
|
.\"
|
2008-01-14 16:57:26 +03:00
|
|
|
.\" Copyright (c) 2006, 2007, 2008 Antti Kantee. All rights reserved.
|
2006-11-09 04:30:15 +03:00
|
|
|
.\"
|
|
|
|
.\" 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.
|
|
|
|
.\"
|
2012-04-08 20:09:55 +04:00
|
|
|
.Dd April 8, 2012
|
2006-11-09 04:30:15 +03:00
|
|
|
.Dt PUFFS 3
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
2007-02-08 08:24:36 +03:00
|
|
|
.Nm puffs
|
2006-11-09 04:30:15 +03:00
|
|
|
.Nd Pass-to-Userspace Framework File System development interface
|
|
|
|
.Sh LIBRARY
|
|
|
|
.Lb libpuffs
|
|
|
|
.Sh SYNOPSIS
|
|
|
|
.In puffs.h
|
|
|
|
.Ft struct puffs_usermount *
|
2007-04-16 20:37:02 +04:00
|
|
|
.Fo puffs_init
|
2007-07-19 02:23:37 +04:00
|
|
|
.Fa "struct puffs_ops *pops" "const char *mntfromname" "const char *puffsname"
|
|
|
|
.Fa "void *private" "uint32_t flags"
|
2007-04-16 20:37:02 +04:00
|
|
|
.Fc
|
|
|
|
.Ft int
|
2006-11-09 04:30:15 +03:00
|
|
|
.Fo puffs_mount
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fa "struct puffs_usermount *pu" "const char *dir" "int mntflags"
|
2008-08-12 23:44:39 +04:00
|
|
|
.Fa "puffs_cookie_t root_cookie"
|
2007-01-20 00:10:55 +03:00
|
|
|
.Fc
|
2006-11-09 04:30:15 +03:00
|
|
|
.Ft int
|
|
|
|
.Fn puffs_getselectable "struct puffs_usermount *pu"
|
|
|
|
.Ft int
|
|
|
|
.Fn puffs_setblockingmode "struct puffs_usermount *pu" "int mode"
|
|
|
|
.Ft int
|
2007-01-20 16:34:35 +03:00
|
|
|
.Fn puffs_getstate "struct puffs_usermount *pu"
|
|
|
|
.Ft int
|
|
|
|
.Fn puffs_setstacksize "struct puffs_usermount *pu" "size_t stacksize"
|
2007-04-13 01:45:29 +04:00
|
|
|
.Ft void
|
|
|
|
.Fn puffs_setroot "struct puffs_usermount *pu" "struct puffs_node *node"
|
2007-05-17 19:21:14 +04:00
|
|
|
.Ft void
|
|
|
|
.Fo puffs_setrootinfo
|
|
|
|
.Fa "struct puffs_usermount *pu" "enum vtype vt" "vsize_t vsize" "dev_t rdev"
|
|
|
|
.Fc
|
2007-04-13 01:45:29 +04:00
|
|
|
.Ft struct puffs_node *
|
|
|
|
.Fn puffs_getroot "struct puffs_usermount *pu"
|
|
|
|
.Ft void *
|
|
|
|
.Fn puffs_getspecific "struct puffs_usermount *pu"
|
2007-04-16 20:37:02 +04:00
|
|
|
.Ft void
|
2008-12-12 21:59:53 +03:00
|
|
|
.Fn puffs_setspecific "struct puffs_usermount *pu" "void *private"
|
|
|
|
.Ft void
|
2007-04-16 20:37:02 +04:00
|
|
|
.Fn puffs_setmaxreqlen "struct puffs_usermount *pu" "size_t maxreqlen"
|
2007-04-13 01:45:29 +04:00
|
|
|
.Ft size_t
|
|
|
|
.Fn puffs_getmaxreqlen "struct puffs_usermount *pu"
|
2007-04-16 20:37:02 +04:00
|
|
|
.Ft void
|
|
|
|
.Fn puffs_setfhsize "struct puffs_usermount *pu" "size_t fhsize" "int flags"
|
|
|
|
.Ft void
|
|
|
|
.Fn puffs_setncookiehash "struct puffs_usermount *pu" "int nhashes"
|
2007-05-15 17:44:46 +04:00
|
|
|
.Ft void
|
|
|
|
.Fn puffs_ml_loop_fn "struct puffs_usermount *pu"
|
|
|
|
.Ft void
|
|
|
|
.Fn puffs_ml_setloopfn "struct puffs_usermount *pu" "puffs_ml_loop_fn lfn"
|
|
|
|
.Ft void
|
|
|
|
.Fn puffs_ml_settimeout "struct puffs_usermount *pu" "struct timespec *ts"
|
|
|
|
.Ft int
|
2007-11-16 21:35:10 +03:00
|
|
|
.Fn puffs_daemon "struct puffs_usermount *pu" "int nochdir" "int noclose"
|
|
|
|
.Ft int
|
2007-11-05 20:48:17 +03:00
|
|
|
.Fn puffs_mainloop "struct puffs_usermount *pu"
|
2007-12-15 23:11:38 +03:00
|
|
|
.Ft int
|
2010-01-12 21:42:38 +03:00
|
|
|
.Fn puffs_unmountonsignal "int sig" "bool ignoresig"
|
|
|
|
.Ft int
|
2008-01-28 21:35:49 +03:00
|
|
|
.Fo puffs_dispatch_create
|
|
|
|
.Fa "struct puffs_usermount *pu" "struct puffs_framebuf *pb"
|
|
|
|
.Fa "struct puffs_cc **pccp"
|
|
|
|
.Fc
|
|
|
|
.Ft int
|
2008-11-14 16:10:13 +03:00
|
|
|
.Fn puffs_dispatch_exec "struct puffs_cc *pcc" "struct puffs_framebuf **pbp"
|
2006-11-09 04:30:15 +03:00
|
|
|
.Sh DESCRIPTION
|
|
|
|
.Nm
|
|
|
|
provides a framework for creating file systems as userspace servers.
|
|
|
|
Operations are transported from the kernel virtual file system layer
|
|
|
|
to the concrete implementation behind
|
|
|
|
.Nm ,
|
|
|
|
where they are processed and results are sent back to the kernel.
|
|
|
|
.Pp
|
|
|
|
It is possible to use
|
|
|
|
.Nm
|
2007-05-15 17:44:46 +04:00
|
|
|
in two different ways.
|
2006-11-30 08:53:34 +03:00
|
|
|
Calling
|
|
|
|
.Fn puffs_mainloop
|
|
|
|
takes execution context away from the caller and automatically handles
|
|
|
|
all requests by using the callbacks.
|
2007-05-15 17:44:46 +04:00
|
|
|
By using
|
2007-05-09 22:24:11 +04:00
|
|
|
.Xr puffs_framebuf 3
|
2007-05-15 17:44:46 +04:00
|
|
|
in conjuction with
|
|
|
|
.Fn puffs_mainloop ,
|
|
|
|
it is possible to handle I/O to and from file descriptors.
|
|
|
|
This is suited e.g. for distributed file servers.
|
2006-11-09 04:30:15 +03:00
|
|
|
.Ss Library operation
|
2007-05-15 17:44:46 +04:00
|
|
|
Operations on the library always require a pointer to the opaque context
|
2007-04-16 20:37:02 +04:00
|
|
|
identifier,
|
|
|
|
.Va struct puffs_usermount .
|
2007-05-17 19:21:14 +04:00
|
|
|
It is obtained by calling
|
|
|
|
.Fn puffs_init .
|
2007-04-16 20:37:02 +04:00
|
|
|
.Pp
|
2007-07-19 02:23:37 +04:00
|
|
|
.Nm
|
|
|
|
operates using operation callbacks.
|
2007-01-20 00:10:55 +03:00
|
|
|
They can be initialized using the macro
|
|
|
|
.Fn PUFFSOP_SET pops fsname type opname ,
|
|
|
|
which will initialize the operation
|
|
|
|
.Fn puffs_type_opname
|
|
|
|
in
|
|
|
|
.Fa pops
|
|
|
|
to
|
|
|
|
.Fn fsname_type_opname .
|
|
|
|
All operations are initialized to a default state with the call
|
|
|
|
.Fn PUFFSOP_INIT pops .
|
2006-11-09 04:30:15 +03:00
|
|
|
All of the VFS routines are mandatory, but all of the node operations
|
|
|
|
with the exception of
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fn puffs_node_lookup
|
2006-11-09 04:30:15 +03:00
|
|
|
are optional.
|
|
|
|
However, leaving operations blank will naturally have an effect on the
|
|
|
|
features available from the file system implementation.
|
2007-07-19 02:23:37 +04:00
|
|
|
.Bl -tag -width xxxx
|
|
|
|
.It Fn puffs_init pops mntfromname puffsname private flags
|
|
|
|
Initializes the library context.
|
|
|
|
.Ar pops
|
|
|
|
specifies the callback operations vector.
|
|
|
|
.Ar mntfromname
|
|
|
|
is device the file system is mounted from.
|
|
|
|
This can be for example a block device such as
|
|
|
|
.Pa /dev/wd0a
|
|
|
|
or, if the file system is pseudo file system, the
|
|
|
|
.Nm
|
|
|
|
device name can be given by
|
|
|
|
.Dv _PATH_PUFFS .
|
|
|
|
This value is used for example in the first column of the output of
|
|
|
|
.Xr mount 8
|
2006-11-09 04:30:15 +03:00
|
|
|
and
|
2007-07-19 02:23:37 +04:00
|
|
|
.Xr df 1 .
|
|
|
|
.Ar puffsname
|
|
|
|
is the file system type.
|
2007-12-01 21:53:28 +03:00
|
|
|
It will always be prepended with the string "puffs|".
|
2007-07-19 02:23:37 +04:00
|
|
|
If possible, file server binaries should be named using the format
|
|
|
|
"mount_myfsnamehere" and this value should equal "myfsnamehere".
|
|
|
|
A file system specific context pointer can optionally be given in
|
|
|
|
.Ar private .
|
|
|
|
This can be retrieved by
|
2007-04-16 20:37:02 +04:00
|
|
|
.Fn puffs_getspecific .
|
2006-11-09 04:30:15 +03:00
|
|
|
Flags for
|
|
|
|
.Nm
|
|
|
|
can be given via
|
|
|
|
.Fa pflags .
|
2007-01-20 00:10:55 +03:00
|
|
|
Currently the following flags are supported:
|
2007-07-06 02:42:14 +04:00
|
|
|
.Bl -tag -width "XPUFFS_KFLAG_LOOKUP_FULLPNBUF"
|
2007-06-25 02:32:00 +04:00
|
|
|
.It Dv PUFFS_KFLAG_NOCACHE_NAME
|
|
|
|
Do not enter pathname components into the name cache.
|
|
|
|
This means that every time the kernel does a lookup for a
|
|
|
|
componentname, the file server will be consulted.
|
|
|
|
.It Dv PUFFS_KFLAG_NOCACHE_PAGE
|
|
|
|
Do not use the page cache.
|
|
|
|
This means that all reads and writes to regular file are
|
|
|
|
propagated to the file server for handling.
|
|
|
|
This option makes a difference only for regular files.
|
2007-01-20 00:10:55 +03:00
|
|
|
.It Dv PUFFS_KFLAG_NOCACHE
|
2007-06-25 02:32:00 +04:00
|
|
|
An alias for both
|
|
|
|
.Dv PUFFS_KFLAG_NOCACHE_NAME
|
|
|
|
and
|
|
|
|
.Dv PUFFS_KFLAG_NOCACHE_PAGE .
|
2007-01-20 00:10:55 +03:00
|
|
|
.It Dv PUFFS_KFLAG_ALLOPS
|
|
|
|
This flag requests that all operations are sent to userspace.
|
|
|
|
Normally the kernel shortcircuits unimplemented operations.
|
|
|
|
This flag is mostly useful for debugging purposes.
|
2007-05-09 17:54:08 +04:00
|
|
|
.It Dv PUFFS_KFLAG_WTCACHE
|
2007-12-01 21:53:28 +03:00
|
|
|
Set the file system cache behavior as write-through.
|
2007-05-09 17:54:08 +04:00
|
|
|
This means that all writes are immediately issued to the file server
|
|
|
|
instead of being flushed in file system sync.
|
|
|
|
This is useful especially for distributed file systems.
|
|
|
|
.It Dv PUFFS_KFLAG_IAONDEMAND
|
|
|
|
Issue inactive only on demand.
|
|
|
|
If a file server defines the inactive method, call it only if the file
|
|
|
|
server has explicitly requested that inactive be called for the
|
|
|
|
node in question.
|
|
|
|
Once inactive has been called for a node, it will not be called
|
|
|
|
again unless the request to call inactive is reissued by the file server.
|
|
|
|
See
|
|
|
|
.Fn puffs_setback
|
|
|
|
in
|
|
|
|
.Xr puffs_ops 3
|
|
|
|
for more information.
|
2007-07-06 02:42:14 +04:00
|
|
|
.It Dv PUFFS_KFLAG_LOOKUP_FULLPNBUF
|
|
|
|
This flag affects only the parameter
|
|
|
|
.Ar pcn to
|
|
|
|
.Fn puffs_node_lookup .
|
|
|
|
If this flag is not given, only the next pathname component under
|
|
|
|
lookup is found from
|
2007-12-01 21:53:28 +03:00
|
|
|
.Ar pcn-\*[Gt]pcn_name .
|
2007-07-06 02:42:14 +04:00
|
|
|
If this flag is given, the full path the kernel was
|
|
|
|
asked to resolve can be found from there.
|
2007-01-20 00:10:55 +03:00
|
|
|
.It Dv PUFFS_FLAG_BUILDPATH
|
|
|
|
The framework will build a complete path name, which is supplied
|
|
|
|
with each operation and can be found from the
|
2011-11-24 05:59:25 +04:00
|
|
|
.Va pcn_po_full.po_path
|
2007-01-20 00:10:55 +03:00
|
|
|
field in a
|
2011-11-24 05:59:25 +04:00
|
|
|
.Vt struct puffs_cn .
|
2007-01-20 00:10:55 +03:00
|
|
|
The option assumes that the framework can map a cookie to a
|
|
|
|
.Vt struct puffs_node .
|
|
|
|
See
|
|
|
|
.Sx Cookies
|
|
|
|
for more information on cookie mapping.
|
|
|
|
See
|
|
|
|
.Xr puffs_path 3
|
|
|
|
for more information on library calls involving paths.
|
2007-05-01 19:58:00 +04:00
|
|
|
.It Dv PUFFS_FLAG_HASHPATH
|
|
|
|
Calculate a hash of the path into the path object field
|
|
|
|
.Va po_hash .
|
|
|
|
This hash value is used by
|
|
|
|
.Fn puffs_path_walkcmp
|
|
|
|
to avoid doing a full comparison for every path equal in length to
|
|
|
|
the one searched for.
|
|
|
|
Especially if the file system uses the abovementioned function, it
|
|
|
|
is a good idea to define this flag.
|
Add PUFFS_KFLAG_CACHE_FS_TTL flag to puffs_init(3) to use name and
attribute cache with filesystem provided TTL.
lookup, create, mknod, mkdir, symlink, getattr and setattr messages
have been extended so that attributes and their TTL can be provided
by the filesytem. lookup, create, mknod, mkdir, and symlink messages
are also extended so that the filesystem can provide name TTL.
The filesystem updates attributes and TTL using
puffs_pn_getvap(3), puffs_pn_getvattl(3), and puffs_pn_getcnttl(3)
2012-04-08 19:07:45 +04:00
|
|
|
.It Dv PUFFS_KFLAG_CACHE_FS_TTL
|
2012-04-08 20:09:55 +04:00
|
|
|
Enforce name and attribute caches based on file system-supplied TTL.
|
2012-04-18 04:57:21 +04:00
|
|
|
In lookup, create, mknod, mkdir, and symlink, the file system must
|
|
|
|
update the node attributes, their TTL, and the node name TTL through
|
|
|
|
.Fn puffs_newinfo_setva ,
|
|
|
|
.Fn puffs_newinfo_setvattl
|
2012-04-08 20:09:55 +04:00
|
|
|
and
|
2012-04-18 04:57:21 +04:00
|
|
|
.Fn puffs_newinfo_setcnttl .
|
Add PUFFS_KFLAG_CACHE_FS_TTL flag to puffs_init(3) to use name and
attribute cache with filesystem provided TTL.
lookup, create, mknod, mkdir, symlink, getattr and setattr messages
have been extended so that attributes and their TTL can be provided
by the filesytem. lookup, create, mknod, mkdir, and symlink messages
are also extended so that the filesystem can provide name TTL.
The filesystem updates attributes and TTL using
puffs_pn_getvap(3), puffs_pn_getvattl(3), and puffs_pn_getcnttl(3)
2012-04-08 19:07:45 +04:00
|
|
|
.Pp
|
2012-04-18 04:57:21 +04:00
|
|
|
Additionally,
|
|
|
|
.Fn puffs_node_getattr_ttl
|
|
|
|
and
|
|
|
|
.Fn puffs_node_setattr_ttl
|
|
|
|
will be called instead of
|
|
|
|
.Fn puffs_node_getattr
|
|
|
|
and
|
|
|
|
.Fn puffs_node_setattr .
|
|
|
|
|
2007-01-20 00:10:55 +03:00
|
|
|
.It Dv PUFFS_FLAG_OPDUMP
|
|
|
|
This option makes the framework dump a textual representation of
|
|
|
|
each operation before executing it.
|
|
|
|
It is useful for debugging purposes.
|
|
|
|
.El
|
2007-07-19 02:23:37 +04:00
|
|
|
.El
|
2007-01-20 00:10:55 +03:00
|
|
|
.Pp
|
2007-04-16 20:37:02 +04:00
|
|
|
The following functions can be used to query or modify the global
|
|
|
|
state of the file system.
|
|
|
|
Note, that all calls are not available at all times.
|
2007-04-13 01:45:29 +04:00
|
|
|
.Bl -tag -width xxxx
|
|
|
|
.It Fn puffs_getselectable "pu"
|
|
|
|
Returns a handle to do I/O multiplexing with:
|
2006-11-09 04:30:15 +03:00
|
|
|
.Xr select 2 ,
|
2006-11-19 03:11:21 +03:00
|
|
|
.Xr poll 2 ,
|
2006-11-09 04:30:15 +03:00
|
|
|
and
|
|
|
|
.Xr kqueue 2
|
2006-11-19 03:11:21 +03:00
|
|
|
are all examples of acceptable operations.
|
2007-04-13 01:45:29 +04:00
|
|
|
.It Fn puffs_setblockingmode "pu" "mode"
|
2007-11-06 18:09:07 +03:00
|
|
|
Sets the file system upstream access to blocking or non-blocking mode.
|
2006-11-09 04:30:15 +03:00
|
|
|
Acceptable values for the argument are
|
|
|
|
.Dv PUFFSDEV_BLOCK
|
|
|
|
and
|
|
|
|
.Dv PUFFSDEV_NONBLOCK .
|
2007-11-06 18:09:07 +03:00
|
|
|
.Pp
|
|
|
|
This routine can be called only after calling
|
|
|
|
.Fn puffs_mount .
|
2007-04-13 01:45:29 +04:00
|
|
|
.It Fn puffs_getstate "pu"
|
|
|
|
Returns the state of the file system.
|
2007-01-20 16:34:35 +03:00
|
|
|
It is maintained by the framework and is mostly useful for the framework
|
|
|
|
itself.
|
|
|
|
Possible values are
|
2007-05-17 19:21:14 +04:00
|
|
|
.Dv PUFFS_STATE_BEFOREMOUNT ,
|
2007-01-20 16:34:35 +03:00
|
|
|
.Dv PUFFS_STATE_RUNNING ,
|
|
|
|
.Dv PUFFS_STATE_UNMOUNTING
|
|
|
|
and
|
|
|
|
.Dv PUFFS_STATE_UNMOUNTED .
|
2008-01-14 16:57:26 +03:00
|
|
|
.It Fn puffs_setstacksize "pu" "stacksize"
|
2007-04-13 01:45:29 +04:00
|
|
|
Sets the stack size used when running callbacks.
|
2008-01-14 16:57:26 +03:00
|
|
|
The default is
|
|
|
|
.Dv PUFFS_STACKSIZE_DEFAULT
|
|
|
|
bytes of stack space per request.
|
|
|
|
The minimum stacksize is architecture-dependent and can be specified
|
|
|
|
by using the opaque constant
|
|
|
|
.Dv PUFFS_STACKSIZE_MIN .
|
2007-04-13 01:45:29 +04:00
|
|
|
.It Fn puffs_setroot "pu" "node"
|
|
|
|
Sets the root node of mount
|
|
|
|
.Fa pu
|
|
|
|
to
|
|
|
|
.Fa "node" .
|
|
|
|
Setting the root node is currently required only if the path
|
|
|
|
framework is used, see
|
|
|
|
.Xr puffs_path 3 .
|
2007-05-17 19:21:14 +04:00
|
|
|
.It Fn puffs_setrootinfo pu vt vsize rdev
|
|
|
|
The default root node is a directory.
|
|
|
|
In case the file system wants something different, it can call this
|
|
|
|
function and set the type, size and possible device type to whatever
|
|
|
|
it wants.
|
|
|
|
This routine is independent of
|
|
|
|
.Fn puffs_setroot .
|
2007-04-13 01:45:29 +04:00
|
|
|
.It Fn puffs_getroot "pu"
|
|
|
|
Returns the root node set earlier.
|
|
|
|
.It Fn puffs_getspecific "pu"
|
|
|
|
Returns the
|
|
|
|
.Fa private
|
|
|
|
argument of
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fn puffs_init .
|
2008-12-12 21:59:53 +03:00
|
|
|
.It Fn puffs_setspecific "pu" "private"
|
|
|
|
Can be used to set the specific data after the call to
|
|
|
|
.Fn puffs_init .
|
2007-04-16 20:37:02 +04:00
|
|
|
.It Fn puffs_setmaxreqlen "pu" "maxreqlen"
|
|
|
|
In case the file system desires a maximum buffer length different from
|
|
|
|
the default, the amount
|
|
|
|
.Fa maxreqlen
|
|
|
|
will be requested from the kernel when the file system is mounted.
|
|
|
|
.Pp
|
|
|
|
It is legal to call this function only between
|
|
|
|
.Fn puffs_init
|
|
|
|
and
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fn puffs_mount .
|
2007-12-05 00:24:10 +03:00
|
|
|
.Pp
|
|
|
|
.Em NOTE
|
|
|
|
This does not currently work.
|
2007-04-13 01:45:29 +04:00
|
|
|
.It Fn puffs_getmaxreqlen "pu"
|
|
|
|
Returns the maximum request length the kernel will need for a single
|
|
|
|
request.
|
2007-12-05 00:24:10 +03:00
|
|
|
.Pp
|
|
|
|
.Em NOTE
|
|
|
|
This does not currently work.
|
2007-04-16 20:37:02 +04:00
|
|
|
.It Fn puffs_setfhsize "pu" "fhsize" "flags"
|
|
|
|
Sets the desired file handle size.
|
2007-12-01 21:53:28 +03:00
|
|
|
This must be called if the file system wishes to support NFS exporting
|
2007-04-16 20:37:02 +04:00
|
|
|
file systems of the
|
|
|
|
.Fn fh*
|
|
|
|
family of function calls.
|
|
|
|
.Pp
|
|
|
|
In case all nodes in the file system produce the same length file handle,
|
|
|
|
it must be supplied as
|
|
|
|
.Fa fhsize .
|
|
|
|
In this case, the file system may ignore the length parameters in the
|
|
|
|
file handle callback routines, as the kernel will always pass the
|
|
|
|
correct length buffer.
|
|
|
|
However, if the file handle size varies according to file, the argument
|
|
|
|
.Fa fhsize
|
|
|
|
defines the maximum size of a file handle for the file system.
|
|
|
|
In this case the file system must take care of the handle lengths by
|
2007-04-16 23:16:02 +04:00
|
|
|
itself in the file handle callbacks, see
|
|
|
|
.Xr puffs_ops 3
|
|
|
|
for more information.
|
2007-04-16 20:37:02 +04:00
|
|
|
Also, the flag
|
|
|
|
.Dv PUFFS_FHFLAG_DYNAMIC
|
|
|
|
must be provided in the argument
|
|
|
|
.Fa flags .
|
|
|
|
.Pp
|
|
|
|
In case the file system wants to sanity check its file handle lengths
|
|
|
|
for the limits of NFS, it can supply
|
|
|
|
.Dv PUFFS_FHFLAG_NFSV2
|
|
|
|
and
|
|
|
|
.Dv PUFFS_FHFLAG_NFSV3
|
|
|
|
in the
|
|
|
|
.Fa flags
|
|
|
|
parameter.
|
|
|
|
It is especially important to note that these are not directly the
|
|
|
|
limits specified by the protocols, as the kernel uses some bytes from
|
|
|
|
the buffer space.
|
|
|
|
In case the file handles are too large, mount will return an error.
|
|
|
|
.Pp
|
|
|
|
It is legal to call this function only between
|
|
|
|
.Fn puffs_init
|
|
|
|
and
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fn puffs_mount .
|
2007-04-16 20:37:02 +04:00
|
|
|
.It Fn puffs_setncookiehash "pu" "ncookiehash"
|
|
|
|
The parameter
|
|
|
|
.Fa ncookiehash
|
|
|
|
controls the amount of hash buckets the kernel has for reverse lookups
|
|
|
|
from cookie to vnode.
|
|
|
|
Technically the default is enough, but a memory/time tradeoff can be
|
|
|
|
made by increasing this for file systems which know they will have
|
|
|
|
very many active files.
|
|
|
|
.Pp
|
|
|
|
It is legal to call this function only between
|
|
|
|
.Fn puffs_init
|
|
|
|
and
|
2007-05-17 19:21:14 +04:00
|
|
|
.Fn puffs_mount .
|
2007-04-13 01:45:29 +04:00
|
|
|
.El
|
2007-01-20 16:34:35 +03:00
|
|
|
.Pp
|
2007-01-20 00:10:55 +03:00
|
|
|
After the correct setup for the library has been established and the
|
2007-07-19 02:23:37 +04:00
|
|
|
backend has been initialized the file system is made operational by calling
|
|
|
|
.Fn puffs_mount .
|
|
|
|
After this function returns the file system should start processing requests.
|
|
|
|
.Bl -tag -width xxxx
|
|
|
|
.It Fn puffs_mount pu dir mntflags root_cookie
|
|
|
|
.Ar pu
|
|
|
|
is the library context pointer from
|
|
|
|
.Fn puffs_init .
|
|
|
|
The argument
|
|
|
|
.Fa dir
|
|
|
|
signifies the mount point and
|
|
|
|
.Fa mntflags
|
|
|
|
is the flagset given to
|
|
|
|
.Xr mount 2 .
|
|
|
|
The value
|
|
|
|
.Ar root_cookie
|
|
|
|
will be used as the cookie for the file system root node.
|
|
|
|
.El
|
2007-05-15 17:44:46 +04:00
|
|
|
.Ss Using the built-in eventloop
|
|
|
|
.Bl -tag -width xxxx
|
|
|
|
.It Fn puffs_ml_loop_fn pu
|
|
|
|
Loop function signature.
|
|
|
|
.It Fn puffs_ml_setloopfn pu lfn
|
|
|
|
Set loop function to
|
|
|
|
.Ar lfn .
|
|
|
|
This function is called once each time the event loop loops.
|
|
|
|
It is not a well-defined interval, but it can be made fairly regular
|
|
|
|
by setting the loop timeout by
|
|
|
|
.Fn puffs_ml_settimeout .
|
|
|
|
.It Fn puffs_ml_settimeout pu ts
|
|
|
|
Sets the loop timeout to
|
|
|
|
.Ar ts
|
|
|
|
or disables it if
|
|
|
|
.Ar ts
|
|
|
|
is
|
|
|
|
.Dv NULL .
|
|
|
|
This can be used to roughly control how often the loop callback
|
|
|
|
.Fn lfn
|
|
|
|
is called
|
2007-11-16 21:35:10 +03:00
|
|
|
.It Fn puffs_daemon pu nochdir noclose
|
|
|
|
Detach from the console like
|
|
|
|
.Fn daemon 3 .
|
|
|
|
This call synchronizes with
|
|
|
|
.Fn puffs_mount
|
|
|
|
and the foreground process does not exit before the file system mount
|
|
|
|
call has returned from the kernel.
|
2008-11-14 16:27:24 +03:00
|
|
|
Since this routine internally calls fork, it has to be called
|
|
|
|
.Em before
|
|
|
|
.Fn puffs_mount .
|
2007-05-15 17:44:46 +04:00
|
|
|
.It Fn puffs_mainloop pu flags
|
|
|
|
Handle all requests automatically until the file system is unmounted.
|
2007-12-01 21:53:28 +03:00
|
|
|
It returns 0 if the file system was successfully unmounted or \-1 if it
|
2007-04-16 20:37:02 +04:00
|
|
|
was killed in action.
|
2007-05-15 17:44:46 +04:00
|
|
|
.Pp
|
|
|
|
In case
|
|
|
|
.Xr puffs_framebuf 3
|
|
|
|
has been initialized, I/O from the relevant descriptors is processed
|
|
|
|
automatically by the eventloop.
|
2010-01-12 21:42:38 +03:00
|
|
|
.It Fn puffs_unmountonsignal signum ignoresig
|
|
|
|
Cause all file servers within the process to initiate unmount upon
|
|
|
|
receipt of signal
|
|
|
|
.Ar signum .
|
|
|
|
This works only for servers which call
|
|
|
|
.Fn puffs_mainloop
|
|
|
|
and must be called before any server within the process enters the mainloop.
|
|
|
|
The process signal handler is still called before starting the unmount
|
|
|
|
procedure.
|
|
|
|
The parameter
|
|
|
|
.Ar ignoresig
|
|
|
|
is provided as a convenience and tells if to install a signal handler
|
|
|
|
to ignore
|
|
|
|
.Ar sig
|
|
|
|
so that the process will not e.g. terminate based on the default action
|
|
|
|
before the file system unmount can be initiated.
|
2008-01-28 21:35:49 +03:00
|
|
|
.It Fn puffs_dispatch_create pu pb pccp
|
|
|
|
.It Fn puffs_dispatch_exec pcc pbp
|
|
|
|
In case the use of
|
|
|
|
.Fn puffs_mainloop
|
|
|
|
is not possible, requests may be dispatched manually.
|
|
|
|
However, as this is less efficient than using the mainloop,
|
|
|
|
it should never be the first preference.
|
|
|
|
.Pp
|
2008-05-25 23:38:14 +04:00
|
|
|
Calling
|
2008-01-28 21:35:49 +03:00
|
|
|
.Fn puffs_dispatch_create
|
|
|
|
creates a dispatch request.
|
|
|
|
The argument
|
2007-12-15 23:11:38 +03:00
|
|
|
.Ar pb
|
2008-01-28 21:35:49 +03:00
|
|
|
should contains a valid request and upon success
|
|
|
|
.Ar pccp
|
|
|
|
will contain a valid request context.
|
|
|
|
This context is passed to
|
|
|
|
.Fn puffs_dispatch_exec
|
|
|
|
to execute the request.
|
|
|
|
If the request yielded before completing, the routine returns 0,
|
|
|
|
otherwise 1.
|
|
|
|
When the routine completes,
|
|
|
|
.Ar pcc
|
|
|
|
is made invalid and a pointer to the processed buffer is placed in
|
|
|
|
.Ar pbp .
|
|
|
|
It is the responsibility of the caller to send the response (if
|
|
|
|
necessary) and destroy the buffer.
|
|
|
|
.Pp
|
|
|
|
See
|
|
|
|
.Xr puffs_cc 3
|
|
|
|
and
|
|
|
|
.Xr puffs_framebuf 3
|
|
|
|
for further information.
|
2007-05-15 17:44:46 +04:00
|
|
|
.El
|
2006-11-09 04:30:15 +03:00
|
|
|
.Ss Cookies
|
|
|
|
Every file (regular file, directory, device node, ...) instance is
|
|
|
|
attached to the kernel using a cookie.
|
|
|
|
A cookie should uniquely map to a file during its lifetime.
|
|
|
|
If file instances are kept in memory, a simple strategy is to use
|
|
|
|
the virtual address of the structure describing the file.
|
|
|
|
The cookie can be recycled when
|
2007-01-20 00:10:55 +03:00
|
|
|
.Fn puffs_node_reclaim
|
2006-11-09 04:30:15 +03:00
|
|
|
is called for a node.
|
2007-01-20 00:10:55 +03:00
|
|
|
.Pp
|
|
|
|
For some operations (such as building paths) the framework needs to map
|
|
|
|
the cookie to the framework-level structure describing a file,
|
|
|
|
.Vt struct puffs_node .
|
|
|
|
It is advisable to simply use the
|
|
|
|
.Vt struct puffs_node
|
|
|
|
address as a cookie and store file system specific data in the private
|
|
|
|
portion of
|
|
|
|
.Vt struct puffs_node .
|
|
|
|
The library assumes this by default.
|
2007-12-01 21:53:28 +03:00
|
|
|
If it is not desirable, the file system implementation can call
|
2007-01-20 00:10:55 +03:00
|
|
|
.Fn puffs_set_cookiemap
|
|
|
|
to provide an alternative cookie-to-node mapping function.
|
2006-11-09 04:30:15 +03:00
|
|
|
.Sh SEE ALSO
|
2007-07-19 02:23:37 +04:00
|
|
|
.Xr mount 2 ,
|
2007-01-20 00:10:55 +03:00
|
|
|
.Xr puffs_cc 3 ,
|
2007-03-22 20:38:09 +03:00
|
|
|
.Xr puffs_cred 3 ,
|
2007-01-20 00:10:55 +03:00
|
|
|
.Xr puffs_flush 3 ,
|
2007-05-15 17:44:46 +04:00
|
|
|
.Xr puffs_framebuf 3 ,
|
2007-01-20 00:10:55 +03:00
|
|
|
.Xr puffs_node 3 ,
|
2007-04-16 23:16:02 +04:00
|
|
|
.Xr puffs_ops 3 ,
|
2007-01-20 16:23:59 +03:00
|
|
|
.Xr puffs_path 3 ,
|
2007-09-03 16:34:21 +04:00
|
|
|
.Xr refuse 3 ,
|
2007-01-20 16:23:59 +03:00
|
|
|
.Xr puffs 4
|
2007-03-13 20:06:10 +03:00
|
|
|
.Rs
|
|
|
|
.%A Antti Kantee
|
|
|
|
.%D March 2007
|
|
|
|
.%J Proceedings of AsiaBSDCon 2007
|
|
|
|
.%P pp. 29-42
|
|
|
|
.%T puffs - Pass-to-Userspace Framework File System
|
|
|
|
.Re
|
2007-09-24 04:22:25 +04:00
|
|
|
.Rs
|
|
|
|
.%A Antti Kantee
|
2007-10-05 04:04:59 +04:00
|
|
|
.%D September 2007
|
|
|
|
.%I Helsinki University of Technology
|
|
|
|
.%R Tech Report TKK-TKO-B157
|
|
|
|
.%T Using puffs for Implementing Client-Server Distributed File Systems
|
|
|
|
.Re
|
|
|
|
.Rs
|
|
|
|
.%A Antti Kantee
|
2007-09-24 04:22:25 +04:00
|
|
|
.%A Alistair Crooks
|
|
|
|
.%D September 2007
|
|
|
|
.%J EuroBSDCon 2007
|
|
|
|
.%T ReFUSE: Userspace FUSE Reimplementation Using puffs
|
|
|
|
.Re
|
2008-09-06 16:39:49 +04:00
|
|
|
.Rs
|
|
|
|
.%A Antti Kantee
|
|
|
|
.%D March 2008
|
|
|
|
.%J Proceedings of AsiaBSDCon 2008
|
|
|
|
.%P pp. 55-70
|
|
|
|
.%T Send and Receive of File System Protocols: Userspace Approach With puffs
|
|
|
|
.Re
|
2006-11-09 04:30:15 +03:00
|
|
|
.Sh HISTORY
|
2006-11-30 08:53:34 +03:00
|
|
|
An unsupported experimental version of
|
2006-11-09 04:30:15 +03:00
|
|
|
.Nm
|
|
|
|
first appeared in
|
|
|
|
.Nx 4.0 .
|
2009-02-20 17:26:56 +03:00
|
|
|
A stable version appeared in
|
|
|
|
.Nx 5.0 .
|
2006-11-09 04:30:15 +03:00
|
|
|
.Sh AUTHORS
|
|
|
|
.An Antti Kantee Aq pooka@iki.fi
|