union.h revision 185283
1271294Sngie/*- 2271294Sngie * Copyright (c) 1994 The Regents of the University of California. 3271294Sngie * Copyright (c) 1994 Jan-Simon Pendry. 4271294Sngie * Copyright (c) 2005, 2006 Masanori Ozawa <ozawa@ongs.co.jp>, ONGS Inc. 5271294Sngie * Copyright (c) 2006 Daichi Goto <daichi@freebsd.org> 6271294Sngie * All rights reserved. 7271294Sngie * 8271294Sngie * This code is derived from software donated to Berkeley by 9271294Sngie * Jan-Simon Pendry. 10271294Sngie * 11271294Sngie * Redistribution and use in source and binary forms, with or without 12271294Sngie * modification, are permitted provided that the following conditions 13271294Sngie * are met: 14271294Sngie * 1. Redistributions of source code must retain the above copyright 15271294Sngie * notice, this list of conditions and the following disclaimer. 16271294Sngie * 2. Redistributions in binary form must reproduce the above copyright 17271294Sngie * notice, this list of conditions and the following disclaimer in the 18271294Sngie * documentation and/or other materials provided with the distribution. 19271294Sngie * 4. Neither the name of the University nor the names of its contributors 20271294Sngie * may be used to endorse or promote products derived from this software 21271294Sngie * without specific prior written permission. 22271294Sngie * 23271294Sngie * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 26 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 33 * SUCH DAMAGE. 34 * 35 * @(#)union.h 8.9 (Berkeley) 12/10/94 36 * $FreeBSD: head/sys/fs/unionfs/union.h 185283 2008-11-25 03:18:35Z daichi $ 37 */ 38 39#ifdef _KERNEL 40 41/* copy method of attr from lower to upper */ 42typedef enum _unionfs_copymode { 43 UNIONFS_TRADITIONAL = 0, 44 UNIONFS_TRANSPARENT, 45 UNIONFS_MASQUERADE 46} unionfs_copymode; 47 48/* whiteout policy of upper layer */ 49typedef enum _unionfs_whitemode { 50 UNIONFS_WHITE_ALWAYS = 0, 51 UNIONFS_WHITE_WHENNEEDED 52} unionfs_whitemode; 53 54struct unionfs_mount { 55 struct vnode *um_lowervp; /* VREFed once */ 56 struct vnode *um_uppervp; /* VREFed once */ 57 struct vnode *um_rootvp; /* ROOT vnode */ 58 unionfs_copymode um_copymode; 59 unionfs_whitemode um_whitemode; 60 uid_t um_uid; 61 gid_t um_gid; 62 u_short um_udir; 63 u_short um_ufile; 64}; 65 66/* unionfs status list */ 67struct unionfs_node_status { 68 LIST_ENTRY(unionfs_node_status) uns_list; /* Status list */ 69 pid_t uns_pid; /* current process id */ 70 int uns_node_flag; /* uns flag */ 71 int uns_lower_opencnt; /* open count of lower */ 72 int uns_upper_opencnt; /* open count of upper */ 73 int uns_lower_openmode; /* open mode of lower */ 74 int uns_readdir_status; /* read status of readdir */ 75}; 76 77/* union node status flags */ 78#define UNS_OPENL_4_READDIR 0x01 /* open lower layer for readdir */ 79 80/* A cache of vnode references */ 81struct unionfs_node { 82 struct vnode *un_lowervp; /* lower side vnode */ 83 struct vnode *un_uppervp; /* upper side vnode */ 84 struct vnode *un_dvp; /* parent unionfs vnode */ 85 struct vnode *un_vnode; /* Back pointer */ 86 LIST_HEAD(, unionfs_node_status) un_unshead; 87 /* unionfs status head */ 88 LIST_HEAD(unionfs_node_hashhead, unionfs_node) *un_hashtbl; 89 /* dir vnode hash table */ 90 LIST_ENTRY(unionfs_node) un_hash; /* hash list entry */ 91 u_long un_hashmask; /* bit mask */ 92 char *un_path; /* path */ 93 int un_flag; /* unionfs node flag */ 94}; 95 96/* 97 * unionfs node flags 98 * It needs the vnode with exclusive lock, when changing the un_flag variable. 99 */ 100#define UNIONFS_OPENEXTL 0x01 /* openextattr (lower) */ 101#define UNIONFS_OPENEXTU 0x02 /* openextattr (upper) */ 102 103#define MOUNTTOUNIONFSMOUNT(mp) ((struct unionfs_mount *)((mp)->mnt_data)) 104#define VTOUNIONFS(vp) ((struct unionfs_node *)(vp)->v_data) 105#define UNIONFSTOV(xp) ((xp)->un_vnode) 106 107int unionfs_init(struct vfsconf *vfsp); 108int unionfs_uninit(struct vfsconf *vfsp); 109int unionfs_nodeget(struct mount *mp, struct vnode *uppervp, struct vnode *lowervp, struct vnode *dvp, struct vnode **vpp, struct componentname *cnp, struct thread *td); 110void unionfs_noderem(struct vnode *vp, struct thread *td); 111void unionfs_get_node_status(struct unionfs_node *unp, struct thread *td, struct unionfs_node_status **unspp); 112void unionfs_tryrem_node_status(struct unionfs_node *unp, struct unionfs_node_status *unsp); 113 114int unionfs_check_rmdir(struct vnode *vp, struct ucred *cred, struct thread *td); 115int unionfs_copyfile(struct unionfs_node *unp, int docopy, struct ucred *cred, struct thread *td); 116void unionfs_create_uppervattr_core(struct unionfs_mount *ump, struct vattr *lva, struct vattr *uva, struct thread *td); 117int unionfs_create_uppervattr(struct unionfs_mount *ump, struct vnode *lvp, struct vattr *uva, struct ucred *cred, struct thread *td); 118int unionfs_mkshadowdir(struct unionfs_mount *ump, struct vnode *duvp, struct unionfs_node *unp, struct componentname *cnp, struct thread *td); 119int unionfs_mkwhiteout(struct vnode *dvp, struct componentname *cnp, struct thread *td, char *path); 120int unionfs_relookup(struct vnode *dvp, struct vnode **vpp, struct componentname *cnp, struct componentname *cn, struct thread *td, char *path, int pathlen, u_long nameiop); 121int unionfs_relookup_for_create(struct vnode *dvp, struct componentname *cnp, struct thread *td); 122int unionfs_relookup_for_delete(struct vnode *dvp, struct componentname *cnp, struct thread *td); 123int unionfs_relookup_for_rename(struct vnode *dvp, struct componentname *cnp, struct thread *td); 124 125#ifdef DIAGNOSTIC 126struct vnode *unionfs_checklowervp(struct vnode *vp, char *fil, int lno); 127struct vnode *unionfs_checkuppervp(struct vnode *vp, char *fil, int lno); 128#define UNIONFSVPTOLOWERVP(vp) unionfs_checklowervp((vp), __FILE__, __LINE__) 129#define UNIONFSVPTOUPPERVP(vp) unionfs_checkuppervp((vp), __FILE__, __LINE__) 130#else 131#define UNIONFSVPTOLOWERVP(vp) (VTOUNIONFS(vp)->un_lowervp) 132#define UNIONFSVPTOUPPERVP(vp) (VTOUNIONFS(vp)->un_uppervp) 133#endif 134 135extern struct vop_vector unionfs_vnodeops; 136 137#ifdef MALLOC_DECLARE 138MALLOC_DECLARE(M_UNIONFSNODE); 139MALLOC_DECLARE(M_UNIONFSPATH); 140#endif 141 142#ifdef UNIONFS_DEBUG 143#define UNIONFSDEBUG(format, args...) printf(format ,## args) 144#else 145#define UNIONFSDEBUG(format, args...) 146#endif /* UNIONFS_DEBUG */ 147 148#endif /* _KERNEL */ 149