summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1999-09-10 16:59:15 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1999-09-10 16:59:15 +0000
commitc8759bf8436684b473fb86971fb78dfbec302044 (patch)
tree192c5d637c53c64490eb6fb2ed798bc5446ce095
parentf77714c7f4a232941861af5e81441bd3542a6f1d (diff)
fixup the uvm_map() call in the uvm_pagealloc_contig() w/
right uvm_map flags values, also fix the error ondition check. couple of spaces vs tabs in the same code spot. art@ ok
-rw-r--r--sys/uvm/uvm_page.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/sys/uvm/uvm_page.c b/sys/uvm/uvm_page.c
index 70ca9b258d3..fa85122f307 100644
--- a/sys/uvm/uvm_page.c
+++ b/sys/uvm/uvm_page.c
@@ -971,18 +971,21 @@ uvm_pagealloc_contig(size, low, high, alignment)
TAILQ_INIT(&pglist);
if (uvm_pglistalloc(size, low, high, alignment, 0,
&pglist, 1, FALSE))
- return 0;
+ return 0;
addr = vm_map_min(kernel_map);
- if (uvm_map(kernel_map, &addr, size, NULL,
- UVM_UNKNOWN_OFFSET, TRUE) != KERN_SUCCESS)
- addr = 0;
+ if (uvm_map(kernel_map, &addr, size, NULL, UVM_UNKNOWN_OFFSET,
+ UVM_MAPFLAG(UVM_PROT_ALL, UVM_PROT_ALL, UVM_INH_NONE,
+ UVM_ADV_RANDOM, 0)) != KERN_SUCCESS) {
+ uvm_pglistfree(&pglist);
+ return 0;
+ }
temp_addr = addr;
for (pg = TAILQ_FIRST(&pglist); pg != NULL;
pg = TAILQ_NEXT(pg, pageq)) {
pg->uobject = uvm.kernel_object;
pg->offset = temp_addr - vm_map_min(kernel_map);
uvm_pageinsert(pg);
- uvm_pagewire(pg);
+ uvm_pagewire(pg);
#if defined(PMAP_NEW)
pmap_kenter_pa(temp_addr, VM_PAGE_TO_PHYS(pg),
VM_PROT_READ|VM_PROT_WRITE);