summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorJeff Roberson <jeff@FreeBSD.org>2002-06-19 20:47:18 +0000
committerJeff Roberson <jeff@FreeBSD.org>2002-06-19 20:47:18 +0000
commit95f24639b7cf6d2da83502af2e82efb5163f3419 (patch)
tree17d5dbfe792aa81e32cccb784b2c6b5a0e949f0e /sys
parent4507bd42c6e3c22cf2c3c0b53b8c87bc7cfff615 (diff)
Notes
Diffstat (limited to 'sys')
-rw-r--r--sys/vm/vm_kern.c14
1 files changed, 10 insertions, 4 deletions
diff --git a/sys/vm/vm_kern.c b/sys/vm/vm_kern.c
index aa7c8850d899..53464d841800 100644
--- a/sys/vm/vm_kern.c
+++ b/sys/vm/vm_kern.c
@@ -347,6 +347,7 @@ kmem_malloc(map, size, flags)
VM_PROT_ALL, VM_PROT_ALL, 0);
for (i = 0; i < size; i += PAGE_SIZE) {
+ int pflags;
/*
* Note: if M_NOWAIT specified alone, allocate from
* interrupt-safe queues only (just the free list). If
@@ -356,10 +357,15 @@ kmem_malloc(map, size, flags)
* are not allowed to mess with the cache queue.
*/
retry:
- m = vm_page_alloc(kmem_object, OFF_TO_IDX(offset + i),
- ((flags & (M_NOWAIT|M_USE_RESERVE)) == M_NOWAIT) ?
- VM_ALLOC_INTERRUPT :
- VM_ALLOC_SYSTEM);
+ if ((flags & (M_NOWAIT|M_USE_RESERVE)) == M_NOWAIT)
+ pflags = VM_ALLOC_INTERRUPT;
+ else
+ pflags = VM_ALLOC_SYSTEM;
+
+ if (flags & M_ZERO)
+ pflags |= VM_ALLOC_ZERO;
+
+ m = vm_page_alloc(kmem_object, OFF_TO_IDX(offset + i), pflags);
/*
* Ran out of space, free everything up and return. Don't need