diff options
author | Jeff Roberson <jeff@FreeBSD.org> | 2002-05-14 21:59:49 +0000 |
---|---|---|
committer | Jeff Roberson <jeff@FreeBSD.org> | 2002-05-14 21:59:49 +0000 |
commit | 0e2d6cc899f79446c0b77c608a93d50d91c255a3 (patch) | |
tree | b464fde9cb43bdc4495f2a53cd53f5c45ffdf630 /sys/kern | |
parent | d93389d676c34ab28aa75b3bbc4cd9a8b5dc86e5 (diff) | |
download | src-0e2d6cc899f79446c0b77c608a93d50d91c255a3.tar.gz src-0e2d6cc899f79446c0b77c608a93d50d91c255a3.zip |
Disable the shared locking namei() code for now. It breaks several stacking
filesystems. This is on hold until the rest of VFS Locking is reviewed and
deemed safe. It can be enabled with 'options LOOKUP_SHARED'.
Notes
Notes:
svn path=/head/; revision=96616
Diffstat (limited to 'sys/kern')
-rw-r--r-- | sys/kern/vfs_cache.c | 8 | ||||
-rw-r--r-- | sys/kern/vfs_extattr.c | 2 | ||||
-rw-r--r-- | sys/kern/vfs_syscalls.c | 2 | ||||
-rw-r--r-- | sys/kern/vfs_vnops.c | 10 |
4 files changed, 11 insertions, 11 deletions
diff --git a/sys/kern/vfs_cache.c b/sys/kern/vfs_cache.c index 49bd83f0b080..6fd537f90b21 100644 --- a/sys/kern/vfs_cache.c +++ b/sys/kern/vfs_cache.c @@ -566,7 +566,7 @@ vfs_cache_lookup(ap) error = cache_lookup(dvp, vpp, cnp); -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED if (!error) { /* We do this because the rest of the system now expects to get * a shared lock, which is later upgraded if LOCKSHARED is not @@ -608,7 +608,7 @@ vfs_cache_lookup(ap) } else if (flags & ISDOTDOT) { VOP_UNLOCK(dvp, 0, td); cnp->cn_flags |= PDIRUNLOCK; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED if ((flags & ISLASTCN) && (flags & LOCKSHARED)) error = vget(vp, LK_SHARED, td); else @@ -622,7 +622,7 @@ vfs_cache_lookup(ap) cnp->cn_flags &= ~PDIRUNLOCK; } } else { -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED if ((flags & ISLASTCN) && (flags & LOCKSHARED)) error = vget(vp, LK_SHARED, td); else @@ -654,7 +654,7 @@ vfs_cache_lookup(ap) return (error); cnp->cn_flags &= ~PDIRUNLOCK; } -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED error = VOP_CACHEDLOOKUP(dvp, vpp, cnp); if (!error) { diff --git a/sys/kern/vfs_extattr.c b/sys/kern/vfs_extattr.c index f256e9e44844..44dec6d4d845 100644 --- a/sys/kern/vfs_extattr.c +++ b/sys/kern/vfs_extattr.c @@ -2585,7 +2585,7 @@ stat(td, uap) int error; struct nameidata nd; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED NDINIT(&nd, LOOKUP, FOLLOW | LOCKSHARED | LOCKLEAF | NOOBJ, UIO_USERSPACE, SCARG(uap, path), td); #else diff --git a/sys/kern/vfs_syscalls.c b/sys/kern/vfs_syscalls.c index f256e9e44844..44dec6d4d845 100644 --- a/sys/kern/vfs_syscalls.c +++ b/sys/kern/vfs_syscalls.c @@ -2585,7 +2585,7 @@ stat(td, uap) int error; struct nameidata nd; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED NDINIT(&nd, LOOKUP, FOLLOW | LOCKSHARED | LOCKLEAF | NOOBJ, UIO_USERSPACE, SCARG(uap, path), td); #else diff --git a/sys/kern/vfs_vnops.c b/sys/kern/vfs_vnops.c index d2d735d480b6..64e26be32ff3 100644 --- a/sys/kern/vfs_vnops.c +++ b/sys/kern/vfs_vnops.c @@ -106,7 +106,7 @@ vn_open_cred(ndp, flagp, cmode, cred) struct vattr vat; struct vattr *vap = &vat; int mode, fmode, error; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED int exclusive; /* The current intended lock state */ exclusive = 0; @@ -149,7 +149,7 @@ restart: ASSERT_VOP_LOCKED(ndp->ni_vp, "create"); fmode &= ~O_TRUNC; vp = ndp->ni_vp; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED exclusive = 1; #endif } else { @@ -167,7 +167,7 @@ restart: } } else { ndp->ni_cnd.cn_nameiop = LOOKUP; -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED ndp->ni_cnd.cn_flags = ((fmode & O_NOFOLLOW) ? NOFOLLOW : FOLLOW) | LOCKSHARED | LOCKLEAF; @@ -213,7 +213,7 @@ restart: * Make sure that a VM object is created for VMIO support. */ if (vn_canvmio(vp) == TRUE) { -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED int flock; if (!exclusive && VOP_GETVOBJECT(vp, NULL) != 0) @@ -236,7 +236,7 @@ restart: *flagp = fmode; return (error); } -#ifndef LOOKUP_EXCLUSIVE +#ifdef LOOKUP_SHARED flock = VOP_ISLOCKED(vp, td); if (!exclusive && flock == LK_EXCLUSIVE) VOP_LOCK(vp, LK_DOWNGRADE, td); |