union_vnops.c (9095719e2b05d6e1673b755809128a6ad3ea1388) | union_vnops.c (93d71a483ca7918e17405cf5f6c163470682c087) |
---|---|
1/* 2 * Copyright (c) 1992, 1993, 1994, 1995 Jan-Simon Pendry. 3 * Copyright (c) 1992, 1993, 1994, 1995 4 * The Regents of the University of California. All rights reserved. 5 * 6 * This code is derived from software contributed to Berkeley by 7 * Jan-Simon Pendry. 8 * --- 21 unchanged lines hidden (view full) --- 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 35 * SUCH DAMAGE. 36 * 37 * @(#)union_vnops.c 8.32 (Berkeley) 6/23/95 | 1/* 2 * Copyright (c) 1992, 1993, 1994, 1995 Jan-Simon Pendry. 3 * Copyright (c) 1992, 1993, 1994, 1995 4 * The Regents of the University of California. All rights reserved. 5 * 6 * This code is derived from software contributed to Berkeley by 7 * Jan-Simon Pendry. 8 * --- 21 unchanged lines hidden (view full) --- 30 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 31 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 32 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 33 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 34 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 35 * SUCH DAMAGE. 36 * 37 * @(#)union_vnops.c 8.32 (Berkeley) 6/23/95 |
38 * $Id: union_vnops.c,v 1.23 1997/04/14 05:13:55 kato Exp $ | 38 * $Id: union_vnops.c,v 1.24 1997/04/15 12:56:57 kato Exp $ |
39 */ 40 41#include <sys/param.h> 42#include <sys/systm.h> 43#include <sys/proc.h> 44#include <sys/fcntl.h> 45#include <sys/time.h> 46#include <sys/stat.h> --- 1006 unchanged lines hidden (view full) --- 1053 } */ *ap; 1054{ 1055 int error = 0; 1056 struct componentname *cnp = ap->a_cnp; 1057 struct proc *p = cnp->cn_proc; 1058 struct union_node *un; 1059 struct vnode *vp; 1060 struct vnode *tdvp; | 39 */ 40 41#include <sys/param.h> 42#include <sys/systm.h> 43#include <sys/proc.h> 44#include <sys/fcntl.h> 45#include <sys/time.h> 46#include <sys/stat.h> --- 1006 unchanged lines hidden (view full) --- 1053 } */ *ap; 1054{ 1055 int error = 0; 1056 struct componentname *cnp = ap->a_cnp; 1057 struct proc *p = cnp->cn_proc; 1058 struct union_node *un; 1059 struct vnode *vp; 1060 struct vnode *tdvp; |
1061 int isvnunlocked = 0; | |
1062 1063 un = VTOUNION(ap->a_tdvp); 1064 1065 if (ap->a_tdvp->v_op != ap->a_vp->v_op) { 1066 vp = ap->a_vp; 1067 } else { 1068 struct union_node *tun = VTOUNION(ap->a_vp); 1069 if (tun->un_uppervp == NULLVP) { --- 22 unchanged lines hidden (view full) --- 1092 return (error); 1093 } 1094 1095 FIXUP(un, p); 1096 VREF(tdvp); 1097 un->un_flags |= UN_KLOCK; 1098 vput(ap->a_tdvp); 1099 | 1061 1062 un = VTOUNION(ap->a_tdvp); 1063 1064 if (ap->a_tdvp->v_op != ap->a_vp->v_op) { 1065 vp = ap->a_vp; 1066 } else { 1067 struct union_node *tun = VTOUNION(ap->a_vp); 1068 if (tun->un_uppervp == NULLVP) { --- 22 unchanged lines hidden (view full) --- 1091 return (error); 1092 } 1093 1094 FIXUP(un, p); 1095 VREF(tdvp); 1096 un->un_flags |= UN_KLOCK; 1097 vput(ap->a_tdvp); 1098 |
1100 /* 1101 * XXX -- This is a quick-hack to avoid panic. Problem still remains! 1102 * The process which access the union filesystem will be hang-up after 1103 * making link in the union fs. 1104 */ 1105 if (VOP_ISLOCKED(tdvp) && (tdvp->v_op != union_vnodeop_p)) { 1106 isvnunlocked = 1; 1107 VOP_UNLOCK(tdvp, 0, p); 1108 } 1109 error = VOP_LINK(vp, tdvp, cnp); 1110 if (isvnunlocked) 1111 vn_lock(tdvp, LK_EXCLUSIVE | LK_RETRY, p); 1112 return error; | 1099 return (VOP_LINK(tdvp, vp, cnp)); |
1113} 1114 1115int 1116union_rename(ap) 1117 struct vop_rename_args /* { 1118 struct vnode *a_fdvp; 1119 struct vnode *a_fvp; 1120 struct componentname *a_fcnp; --- 644 unchanged lines hidden --- | 1100} 1101 1102int 1103union_rename(ap) 1104 struct vop_rename_args /* { 1105 struct vnode *a_fdvp; 1106 struct vnode *a_fvp; 1107 struct componentname *a_fcnp; --- 644 unchanged lines hidden --- |