summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>2001-12-02 23:37:53 +0000
committerArtur Grabowski <art@cvs.openbsd.org>2001-12-02 23:37:53 +0000
commit1131dd56808d1b9a9c9ac943dbb414a6982c6f7c (patch)
tree79ba2a989832dc3697961d093c4cb96203c61fd0
parentd56eeb75438fc0d3564e881a41a21b4293e9242e (diff)
VOP_GETPAGES expects the vnode locked. Make it so.
Note that VOP_PUTPAGES has the same problems, but the fix will be more complicated.
-rw-r--r--sys/uvm/uvm_vnode.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/sys/uvm/uvm_vnode.c b/sys/uvm/uvm_vnode.c
index ca8a2551493..10e75532731 100644
--- a/sys/uvm/uvm_vnode.c
+++ b/sys/uvm/uvm_vnode.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvm_vnode.c,v 1.27 2001/11/28 19:28:15 art Exp $ */
+/* $OpenBSD: uvm_vnode.c,v 1.28 2001/12/02 23:37:52 art Exp $ */
/* $NetBSD: uvm_vnode.c,v 1.50 2001/05/26 21:27:21 chs Exp $ */
/*
@@ -79,10 +79,10 @@ static int uvn_findpage __P((struct uvm_object *, voff_t,
struct vm_page **, int));
boolean_t uvn_flush __P((struct uvm_object *, voff_t, voff_t,
int));
-static int uvn_get __P((struct uvm_object *, voff_t,
+int uvn_get __P((struct uvm_object *, voff_t,
struct vm_page **, int *, int, vm_prot_t,
int, int));
-static int uvn_put __P((struct uvm_object *, struct vm_page **,
+int uvn_put __P((struct uvm_object *, struct vm_page **,
int, boolean_t));
static void uvn_reference __P((struct uvm_object *));
static boolean_t uvn_releasepg __P((struct vm_page *,
@@ -817,7 +817,7 @@ uvn_cluster(uobj, offset, loffset, hoffset)
* => note: caller must set PG_CLEAN and pmap_clear_modify (if needed)
*/
-static int
+int
uvn_put(uobj, pps, npages, flags)
struct uvm_object *uobj;
struct vm_page **pps;
@@ -842,7 +842,7 @@ uvn_put(uobj, pps, npages, flags)
* => NOTE: caller must check for released pages!!
*/
-static int
+int
uvn_get(uobj, offset, pps, npagesp, centeridx, access_type, advice, flags)
struct uvm_object *uobj;
voff_t offset;
@@ -853,12 +853,20 @@ uvn_get(uobj, offset, pps, npagesp, centeridx, access_type, advice, flags)
int advice, flags;
{
struct vnode *vp = (struct vnode *)uobj;
+ struct proc *p = curproc;
int error;
UVMHIST_FUNC("uvn_get"); UVMHIST_CALLED(ubchist);
UVMHIST_LOG(ubchist, "vp %p off 0x%x", vp, (int)offset, 0,0);
+ error = vn_lock(vp, LK_EXCLUSIVE|LK_RECURSEFAIL|LK_NOWAIT, p);
+ if (error) {
+ if (error == EBUSY)
+ return EAGAIN;
+ return error;
+ }
error = VOP_GETPAGES(vp, offset, pps, npagesp, centeridx,
- access_type, advice, flags);
+ access_type, advice, flags);
+ VOP_UNLOCK(vp, LK_RELEASE, p);
return error;
}