summaryrefslogtreecommitdiffstats
path: root/sys/vm/vm_pageout.c
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-04-24 04:31:25 +0000
committeralc <alc@FreeBSD.org>2003-04-24 04:31:25 +0000
commit87da2c3cf37429dd7554a13d8b70a046ccc3edcf (patch)
tree524c091529a13b4f30095fe4af93a54b4cd973f6 /sys/vm/vm_pageout.c
parent51f01cb3f731c451c22c07d8bb6a6e9ecffb72d1 (diff)
downloadFreeBSD-src-87da2c3cf37429dd7554a13d8b70a046ccc3edcf.zip
FreeBSD-src-87da2c3cf37429dd7554a13d8b70a046ccc3edcf.tar.gz
- Acquire the vm_object's lock when performing vm_object_page_clean().
- Add a parameter to vm_pageout_flush() that tells vm_pageout_flush() whether its caller has locked the vm_object. (This is a temporary measure to bootstrap vm_object locking.)
Diffstat (limited to 'sys/vm/vm_pageout.c')
-rw-r--r--sys/vm/vm_pageout.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sys/vm/vm_pageout.c b/sys/vm/vm_pageout.c
index 9c5afcf..c688d61 100644
--- a/sys/vm/vm_pageout.c
+++ b/sys/vm/vm_pageout.c
@@ -348,7 +348,7 @@ more:
/*
* we allow reads during pageouts...
*/
- return vm_pageout_flush(&mc[page_base], pageout_count, 0);
+ return vm_pageout_flush(&mc[page_base], pageout_count, 0, FALSE);
}
/*
@@ -361,10 +361,11 @@ more:
* the ordering.
*/
int
-vm_pageout_flush(mc, count, flags)
+vm_pageout_flush(mc, count, flags, is_object_locked)
vm_page_t *mc;
int count;
int flags;
+ int is_object_locked;
{
vm_object_t object;
int pageout_status[count];
@@ -389,7 +390,8 @@ vm_pageout_flush(mc, count, flags)
}
object = mc[0]->object;
vm_page_unlock_queues();
- VM_OBJECT_LOCK(object);
+ if (!is_object_locked)
+ VM_OBJECT_LOCK(object);
vm_object_pip_add(object, count);
VM_OBJECT_UNLOCK(object);
@@ -442,7 +444,8 @@ vm_pageout_flush(mc, count, flags)
pmap_page_protect(mt, VM_PROT_READ);
}
}
- VM_OBJECT_UNLOCK(object);
+ if (!is_object_locked)
+ VM_OBJECT_UNLOCK(object);
return numpagedout;
}
OpenPOWER on IntegriCloud