summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/uvm/uvm_km.c24
1 files changed, 14 insertions, 10 deletions
diff --git a/sys/uvm/uvm_km.c b/sys/uvm/uvm_km.c
index 7a6c67ae568..53ba23aa740 100644
--- a/sys/uvm/uvm_km.c
+++ b/sys/uvm/uvm_km.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uvm_km.c,v 1.48 2005/10/06 03:59:50 brad Exp $ */
+/* $OpenBSD: uvm_km.c,v 1.49 2006/03/06 19:11:03 mickey Exp $ */
/* $NetBSD: uvm_km.c,v 1.42 2001/01/14 02:10:01 thorpej Exp $ */
/*
@@ -998,23 +998,27 @@ uvm_km_thread(void *arg)
struct km_page *head, *tail, *page;
int i, s, want;
- for (;;) {
- if (uvm_km_pages_free >= uvm_km_pages_lowat)
+ for (i = want = 16; ; ) {
+ if (i < want || uvm_km_pages_free >= uvm_km_pages_lowat)
tsleep(&uvm_km_pages_head, PVM, "kmalloc", 0);
- want = 16;
for (i = 0; i < want; i++) {
page = (void *)uvm_km_alloc(kernel_map, PAGE_SIZE);
if (i == 0)
head = tail = page;
+ if (page == NULL)
+ break;
page->next = head;
head = page;
}
- s = splvm();
- tail->next = uvm_km_pages_head;
- uvm_km_pages_head = head;
- uvm_km_pages_free += i;
- splx(s);
- wakeup(&uvm_km_pages_free);
+ if (head != NULL) {
+ s = splvm();
+ tail->next = uvm_km_pages_head;
+ uvm_km_pages_head = head;
+ uvm_km_pages_free += i;
+ splx(s);
+ }
+ if (uvm_km_pages_free)
+ wakeup(&uvm_km_pages_free);
}
}