summaryrefslogtreecommitdiffstats
path: root/sys/nfsclient/nfs_vnops.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/nfsclient/nfs_vnops.c')
-rw-r--r--sys/nfsclient/nfs_vnops.c42
1 files changed, 23 insertions, 19 deletions
diff --git a/sys/nfsclient/nfs_vnops.c b/sys/nfsclient/nfs_vnops.c
index 14a50c1..8b4b1e1 100644
--- a/sys/nfsclient/nfs_vnops.c
+++ b/sys/nfsclient/nfs_vnops.c
@@ -3038,18 +3038,19 @@ done:
static int
nfs_advlock(struct vop_advlock_args *ap)
{
+ struct vnode *vp = ap->a_vp;
+ u_quad_t size;
int error;
-
- mtx_lock(&Giant);
- if ((VFSTONFS(ap->a_vp->v_mount)->nm_flag & NFSMNT_NOLOCKD) != 0) {
- struct nfsnode *np = VTONFS(ap->a_vp);
- error = lf_advlock(ap, &(np->n_lockf), np->n_size);
- goto out;
- }
- error = nfs_dolock(ap);
-out:
- mtx_unlock(&Giant);
+ error = vn_lock(vp, LK_SHARED);
+ if (error)
+ return (error);
+ if ((VFSTONFS(vp->v_mount)->nm_flag & NFSMNT_NOLOCKD) != 0) {
+ size = VTONFS(vp)->n_size;
+ VOP_UNLOCK(vp, 0);
+ error = lf_advlock(ap, &(vp->v_lockf), size);
+ } else
+ error = nfs_dolock(ap);
return (error);
}
@@ -3059,18 +3060,21 @@ out:
static int
nfs_advlockasync(struct vop_advlockasync_args *ap)
{
+ struct vnode *vp = ap->a_vp;
+ u_quad_t size;
int error;
- mtx_lock(&Giant);
- if ((VFSTONFS(ap->a_vp->v_mount)->nm_flag & NFSMNT_NOLOCKD) != 0) {
- struct nfsnode *np = VTONFS(ap->a_vp);
-
- error = lf_advlockasync(ap, &(np->n_lockf), np->n_size);
- goto out;
+ error = vn_lock(vp, LK_SHARED);
+ if (error)
+ return (error);
+ if ((VFSTONFS(vp->v_mount)->nm_flag & NFSMNT_NOLOCKD) != 0) {
+ size = VTONFS(vp)->n_size;
+ VOP_UNLOCK(vp, 0);
+ error = lf_advlockasync(ap, &(vp->v_lockf), size);
+ } else {
+ VOP_UNLOCK(vp, 0);
+ error = EOPNOTSUPP;
}
- error = EOPNOTSUPP;
-out:
- mtx_unlock(&Giant);
return (error);
}
OpenPOWER on IntegriCloud