diff options
author | jhb <jhb@FreeBSD.org> | 2009-02-13 18:18:14 +0000 |
---|---|---|
committer | jhb <jhb@FreeBSD.org> | 2009-02-13 18:18:14 +0000 |
commit | 26e338d6fc4cd60255a131cdf285a3c2cb66cea4 (patch) | |
tree | 059be0daffb9368cf7dc8f5d8a29ff30ea6391fb /sys/kern/vfs_syscalls.c | |
parent | 482df37a9ec093145af5d2f758f6e565fba7980d (diff) | |
download | FreeBSD-src-26e338d6fc4cd60255a131cdf285a3c2cb66cea4.zip FreeBSD-src-26e338d6fc4cd60255a131cdf285a3c2cb66cea4.tar.gz |
Use shared vnode locks when invoking VOP_READDIR().
MFC after: 1 month
Diffstat (limited to 'sys/kern/vfs_syscalls.c')
-rw-r--r-- | sys/kern/vfs_syscalls.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/sys/kern/vfs_syscalls.c b/sys/kern/vfs_syscalls.c index be3dc76..80da9b7 100644 --- a/sys/kern/vfs_syscalls.c +++ b/sys/kern/vfs_syscalls.c @@ -3936,7 +3936,7 @@ unionread: auio.uio_segflg = UIO_USERSPACE; auio.uio_td = td; auio.uio_resid = uap->count; - vn_lock(vp, LK_EXCLUSIVE | LK_RETRY); + vn_lock(vp, LK_SHARED | LK_RETRY); loff = auio.uio_offset = fp->f_offset; #ifdef MAC error = mac_vnode_check_readdir(td->td_ucred, vp); @@ -4095,8 +4095,7 @@ unionread: auio.uio_segflg = UIO_USERSPACE; auio.uio_td = td; auio.uio_resid = count; - /* vn_lock(vp, LK_SHARED | LK_RETRY); */ - vn_lock(vp, LK_EXCLUSIVE | LK_RETRY); + vn_lock(vp, LK_SHARED | LK_RETRY); AUDIT_ARG(vnode, vp, ARG_VNODE1); loff = auio.uio_offset = fp->f_offset; #ifdef MAC |