summaryrefslogtreecommitdiffstats
path: root/sys/vm/vm_page.c
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2002-07-18 04:08:10 +0000
committeralc <alc@FreeBSD.org>2002-07-18 04:08:10 +0000
commitbf14f2641b55a6ad0f889aa2b0ff3240ad1cc384 (patch)
treed36c6bd5e594479dd64d78868dd7e7d2fb35a878 /sys/vm/vm_page.c
parentcc2882c16b223d38b64f938d27b4b686d3892590 (diff)
downloadFreeBSD-src-bf14f2641b55a6ad0f889aa2b0ff3240ad1cc384.zip
FreeBSD-src-bf14f2641b55a6ad0f889aa2b0ff3240ad1cc384.tar.gz
o Introduce an argument, VM_ALLOC_WIRED, that requests vm_page_alloc()
to return a wired page. o Use VM_ALLOC_WIRED within Alpha's pmap_growkernel(). Also, because Alpha's pmap_growkernel() calls vm_page_alloc() from within a critical section, specify VM_ALLOC_INTERRUPT instead of VM_ALLOC_SYSTEM. (Only VM_ALLOC_INTERRUPT is implemented entirely with a spin mutex.) o Assert that the page queues mutex is held in vm_page_wire() on Alpha, just like the other platforms.
Diffstat (limited to 'sys/vm/vm_page.c')
-rw-r--r--sys/vm/vm_page.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/sys/vm/vm_page.c b/sys/vm/vm_page.c
index 7dd2300..e62e0d1 100644
--- a/sys/vm/vm_page.c
+++ b/sys/vm/vm_page.c
@@ -834,19 +834,17 @@ vm_page_select_free(vm_object_t object, vm_pindex_t pindex, boolean_t prefer_zer
* the page cache in this case.
*/
vm_page_t
-vm_page_alloc(vm_object_t object, vm_pindex_t pindex, int page_req)
+vm_page_alloc(vm_object_t object, vm_pindex_t pindex, int req)
{
vm_page_t m = NULL;
- boolean_t prefer_zero;
- int s;
+ int page_req, s;
GIANT_REQUIRED;
KASSERT(!vm_page_lookup(object, pindex),
("vm_page_alloc: page already allocated"));
- prefer_zero = (page_req & VM_ALLOC_ZERO) != 0 ? TRUE : FALSE;
- page_req &= ~VM_ALLOC_ZERO;
+ page_req = req & VM_ALLOC_CLASS_MASK;
/*
* The pager is allowed to eat deeper into the free page list.
@@ -863,7 +861,8 @@ loop:
* Allocate from the free queue if there are plenty of pages
* in it.
*/
- m = vm_page_select_free(object, pindex, prefer_zero);
+ m = vm_page_select_free(object, pindex,
+ (req & VM_ALLOC_ZERO) != 0);
} else if (
(page_req == VM_ALLOC_SYSTEM &&
cnt.v_cache_count == 0 &&
@@ -934,7 +933,11 @@ loop:
} else {
m->flags = PG_BUSY;
}
- m->wire_count = 0;
+ if (req & VM_ALLOC_WIRED) {
+ cnt.v_wire_count++;
+ m->wire_count = 1;
+ } else
+ m->wire_count = 0;
m->hold_count = 0;
m->act_count = 0;
m->busy = 0;
@@ -1241,9 +1244,7 @@ vm_page_wire(vm_page_t m)
* it is already off the queues).
*/
s = splvm();
-#ifndef __alpha__
mtx_assert(&vm_page_queue_mtx, MA_OWNED);
-#endif
if (m->wire_count == 0) {
if ((m->flags & PG_UNMANAGED) == 0)
vm_pageq_remove(m);
OpenPOWER on IntegriCloud