summaryrefslogtreecommitdiff
path: root/sys/miscfs/genfs/layer.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/miscfs/genfs/layer.h')
-rw-r--r--sys/miscfs/genfs/layer.h167
1 files changed, 167 insertions, 0 deletions
diff --git a/sys/miscfs/genfs/layer.h b/sys/miscfs/genfs/layer.h
new file mode 100644
index 00000000000..c2e4451c16e
--- /dev/null
+++ b/sys/miscfs/genfs/layer.h
@@ -0,0 +1,167 @@
+/* $OpenBSD: layer.h,v 1.1 2003/05/12 20:58:40 tedu Exp $ */
+/* $NetBSD: layer.h,v 1.4 2001/06/07 13:32:46 wiz Exp $ */
+
+/*
+ * Copyright (c) 1999 National Aeronautics & Space Administration
+ * All rights reserved.
+ *
+ * This software was written by William Studenmund of the
+ * Numerical Aerospace Simulation Facility, NASA Ames Research Center.
+ *
+ * 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. Neither the name of the National Aeronautics & Space Administration
+ * 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 NATIONAL AERONAUTICS & SPACE ADMINISTRATION
+ * ``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 ADMINISTRATION OR CONTRIB-
+ * UTORS 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.
+ */
+
+/*
+ * Copyright (c) 1992, 1993
+ * The Regents of the University of California. All rights reserved.
+ *
+ * This code is derived from software donated to Berkeley by
+ * Jan-Simon Pendry.
+ *
+ * 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 University of
+ * California, Berkeley and its contributors.
+ * 4. Neither the name of the University 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 REGENTS 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 REGENTS 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.
+ *
+ * from: Id: lofs.h,v 1.8 1992/05/30 10:05:43 jsp Exp
+ * @(#)null.h 8.2 (Berkeley) 1/21/94
+ */
+
+#ifndef _MISCFS_GENFS_LAYER_H_
+#define _MISCFS_GENFS_LAYER_H_
+
+struct layer_args {
+ char *target; /* Target of loopback */
+ struct export_args export; /* network export info */
+};
+
+#ifdef _KERNEL
+
+struct layer_node;
+
+LIST_HEAD(layer_node_hashhead, layer_node);
+
+struct layer_mount {
+ struct mount *layerm_vfs;
+ struct vnode *layerm_rootvp; /* Ref to root layer_node */
+ struct netexport layerm_export; /* export info */
+ u_int layerm_flags; /* mount point layer flags */
+ u_int layerm_size; /* size of fs's struct node */
+ enum vtype layerm_tag; /* vtag of our vnodes */
+ int /* bypass routine for this mount */
+ (*layerm_bypass)(void *);
+ int (*layerm_alloc) /* alloc a new layer node */
+ (struct mount *, struct vnode *,
+ struct vnode **);
+ int /* ops for our nodes */
+ (**layerm_vnodeop_p)(void *);
+ struct layer_node_hashhead /* head of hash list for layer_nodes */
+ *layerm_node_hashtbl;
+ u_long layerm_node_hash; /* hash mask for hash chain */
+ struct simplelock layerm_hashlock; /* interlock for hash chain. */
+};
+
+#define LAYERFS_MFLAGS 0x00000fff /* reserved layer mount flags */
+#define LAYERFS_MBYPASSDEBUG 0x00000001
+
+/*
+ * A cache of vnode references
+ */
+struct layer_node {
+ LIST_ENTRY(layer_node) layer_hash; /* Hash list */
+ struct vnode *layer_lowervp; /* VREFed once */
+ struct vnode *layer_vnode; /* Back pointer */
+ unsigned int layer_flags; /* locking, etc. */
+};
+
+#define LAYERFS_RESFLAGS 0x00000fff /* flags reserved for layerfs */
+
+/*
+ * The following macros handle upperfs-specific locking. They are needed
+ * when the lowerfs does not export a struct lock for locking use by the
+ * upper layers. These macros are inteded for adjusting the upperfs
+ * struct lock to reflect changes in the underlying vnode's lock state.
+ */
+#define LAYERFS_UPPERLOCK(v, f, r) do { \
+ if ((v)->v_vnlock == NULL) \
+ r = lockmgr(&(v)->v_lock, (f), &(v)->v_interlock, curproc); \
+ else \
+ r = 0; \
+ } while (0)
+
+#define LAYERFS_UPPERUNLOCK(v, f, r) do { \
+ if ((v)->v_vnlock == NULL) \
+ r = lockmgr(&(v)->v_lock, (f) | LK_RELEASE, &(v)->v_interlock, curproc); \
+ else \
+ r = 0; \
+ } while (0)
+
+#define LAYERFS_UPPERISLOCKED(v, r) do { \
+ if ((v)->v_vnlock == NULL) \
+ r = lockstatus(&(v)->v_lock); \
+ else \
+ r = -1; \
+ } while (0)
+
+#define LAYERFS_DO_BYPASS(vp, ap) \
+ (*MOUNTTOLAYERMOUNT((vp)->v_mount)->layerm_bypass)((ap))
+
+extern struct vnode *layer_checkvp(struct vnode *vp, char *fil, int lno);
+
+#define MOUNTTOLAYERMOUNT(mp) ((struct layer_mount *)((mp)->mnt_data))
+#define VTOLAYER(vp) ((struct layer_node *)(vp)->v_data)
+#define LAYERTOV(xp) ((xp)->layer_vnode)
+#ifdef LAYERFS_DIAGNOSTIC
+#define LAYERVPTOLOWERVP(vp) layer_checkvp((vp), __FILE__, __LINE__)
+#else
+#define LAYERVPTOLOWERVP(vp) (VTOLAYER(vp)->layer_lowervp)
+#endif
+
+#endif /* _KERNEL */
+#endif /* _MISCFS_GENFS_LAYER_H_ */