summaryrefslogtreecommitdiffstats
path: root/sys/vm
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2010-05-08 21:35:51 +0000
committeralc <alc@FreeBSD.org>2010-05-08 21:35:51 +0000
commit59b934ef4016aab6f15404750fdcf3f77310bab1 (patch)
tree79d9a12a391cd10bf42c0efa85c0e4e51ff8c28b /sys/vm
parent40b44f9713de70170857e6291876dfce94b6ef43 (diff)
downloadFreeBSD-src-59b934ef4016aab6f15404750fdcf3f77310bab1.zip
FreeBSD-src-59b934ef4016aab6f15404750fdcf3f77310bab1.tar.gz
Minimize the scope of the page queues lock in vm_fault().
Diffstat (limited to 'sys/vm')
-rw-r--r--sys/vm/vm_fault.c3
-rw-r--r--sys/vm/vm_page.c5
2 files changed, 3 insertions, 5 deletions
diff --git a/sys/vm/vm_fault.c b/sys/vm/vm_fault.c
index e5673de..e28c16c 100644
--- a/sys/vm/vm_fault.c
+++ b/sys/vm/vm_fault.c
@@ -306,7 +306,6 @@ RetryFault:;
* which is not what we want.
*/
vm_page_lock(fs.m);
- vm_page_lock_queues();
if ((fs.m->cow) &&
(fault_type & VM_PROT_WRITE) &&
(fs.object == fs.first_object)) {
@@ -337,6 +336,7 @@ RetryFault:;
* sleeping so that the page daemon is less
* likely to reclaim it.
*/
+ vm_page_lock_queues();
vm_page_flag_set(fs.m, PG_REFERENCED);
vm_page_unlock_queues();
vm_page_unlock(fs.m);
@@ -363,6 +363,7 @@ RetryFault:;
vm_object_deallocate(fs.first_object);
goto RetryFault;
}
+ vm_page_lock_queues();
vm_pageq_remove(fs.m);
vm_page_unlock_queues();
vm_page_unlock(fs.m);
diff --git a/sys/vm/vm_page.c b/sys/vm/vm_page.c
index 5a8356e..f8a3259 100644
--- a/sys/vm/vm_page.c
+++ b/sys/vm/vm_page.c
@@ -2233,6 +2233,7 @@ vm_page_cowfault(vm_page_t m)
vm_object_t object;
vm_pindex_t pindex;
+ mtx_assert(&vm_page_queue_mtx, MA_NOTOWNED);
vm_page_lock_assert(m, MA_OWNED);
object = m->object;
VM_OBJECT_LOCK_ASSERT(object, MA_OWNED);
@@ -2243,7 +2244,6 @@ vm_page_cowfault(vm_page_t m)
retry_alloc:
pmap_remove_all(m);
- vm_page_unlock_queues();
vm_page_remove(m);
mnew = vm_page_alloc(object, pindex, VM_ALLOC_NORMAL | VM_ALLOC_NOBUSY);
if (mnew == NULL) {
@@ -2254,7 +2254,6 @@ vm_page_cowfault(vm_page_t m)
VM_OBJECT_LOCK(object);
if (m == vm_page_lookup(object, pindex)) {
vm_page_lock(m);
- vm_page_lock_queues();
goto retry_alloc;
} else {
/*
@@ -2272,9 +2271,7 @@ vm_page_cowfault(vm_page_t m)
*/
vm_page_unlock(m);
vm_page_lock(mnew);
- vm_page_lock_queues();
vm_page_free(mnew);
- vm_page_unlock_queues();
vm_page_unlock(mnew);
vm_page_insert(m, object, pindex);
} else { /* clear COW & copy page */
OpenPOWER on IntegriCloud