summaryrefslogtreecommitdiffstats
path: root/sys/nfs
diff options
context:
space:
mode:
authorjhb <jhb@FreeBSD.org>2001-05-23 22:26:05 +0000
committerjhb <jhb@FreeBSD.org>2001-05-23 22:26:05 +0000
commitc1ce7745c1255fcfe87bccd243b8eb31350f9b08 (patch)
treef84f49174009a05145ee8f1ebb919561f3ca0129 /sys/nfs
parent7de84bf1d3fe963919ae9891204f294cfaa5ab9e (diff)
downloadFreeBSD-src-c1ce7745c1255fcfe87bccd243b8eb31350f9b08.zip
FreeBSD-src-c1ce7745c1255fcfe87bccd243b8eb31350f9b08.tar.gz
Assert Giant is held by the caller rather than getting it and releasing
it in getpages/putpages.
Diffstat (limited to 'sys/nfs')
-rw-r--r--sys/nfs/nfs_bio.c12
1 files changed, 2 insertions, 10 deletions
diff --git a/sys/nfs/nfs_bio.c b/sys/nfs/nfs_bio.c
index 234815c..5ff95e3 100644
--- a/sys/nfs/nfs_bio.c
+++ b/sys/nfs/nfs_bio.c
@@ -118,6 +118,7 @@ nfs_getpages(ap)
pages = ap->a_m;
count = ap->a_count;
+ mtx_assert(&Giant, MA_OWNED);
if (vp->v_object == NULL) {
printf("nfs_getpages: called with non-merged cache vnode??\n");
return VM_PAGER_ERROR;
@@ -126,9 +127,7 @@ nfs_getpages(ap)
if ((nmp->nm_flag & NFSMNT_NFSV3) != 0 &&
(nmp->nm_state & NFSSTA_GOTFSINFO) == 0) {
mtx_unlock(&vm_mtx);
- mtx_lock(&Giant);
(void)nfs_fsinfo(nmp, vp, cred, p);
- mtx_unlock(&Giant);
mtx_lock(&vm_mtx);
}
@@ -174,9 +173,7 @@ nfs_getpages(ap)
uio.uio_procp = p;
mtx_unlock(&vm_mtx);
- mtx_lock(&Giant);
error = nfs_readrpc(vp, &uio, cred);
- mtx_unlock(&Giant);
mtx_lock(&vm_mtx);
pmap_qremove(kva, npages);
@@ -288,12 +285,11 @@ nfs_putpages(ap)
npages = btoc(count);
offset = IDX_TO_OFF(pages[0]->pindex);
+ mtx_assert(&Giant, MA_OWNED);
if ((nmp->nm_flag & NFSMNT_NFSV3) != 0 &&
(nmp->nm_state & NFSSTA_GOTFSINFO) == 0) {
mtx_unlock(&vm_mtx);
- mtx_lock(&Giant);
(void)nfs_fsinfo(nmp, vp, cred, p);
- mtx_unlock(&Giant);
mtx_lock(&vm_mtx);
}
@@ -336,9 +332,7 @@ nfs_putpages(ap)
iomode = NFSV3WRITE_FILESYNC;
mtx_unlock(&vm_mtx);
- mtx_lock(&Giant);
error = nfs_writerpc(vp, &uio, cred, &iomode, &must_commit);
- mtx_unlock(&Giant);
mtx_lock(&vm_mtx);
pmap_qremove(kva, npages);
@@ -352,9 +346,7 @@ nfs_putpages(ap)
}
if (must_commit) {
mtx_unlock(&vm_mtx);
- mtx_lock(&Giant);
nfs_clearcommit(vp->v_mount);
- mtx_unlock(&Giant);
mtx_lock(&vm_mtx);
}
}
OpenPOWER on IntegriCloud