Module Name: src
Committed By: matt
Date: Sat Nov 8 08:01:34 UTC 2014
Modified Files:
src/sys/arch/arm/arm32: pmap.c
Log Message:
When allocing a l1page, if a page isn't available, use uvm_wait to wait
for one to become available. Should fix PR/49364.
To generate a diff of this commit:
cvs rdiff -u -r1.311 -r1.312 src/sys/arch/arm/arm32/pmap.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/arch/arm/arm32/pmap.c
diff -u src/sys/arch/arm/arm32/pmap.c:1.311 src/sys/arch/arm/arm32/pmap.c:1.312
--- src/sys/arch/arm/arm32/pmap.c:1.311 Fri Nov 7 12:44:58 2014
+++ src/sys/arch/arm/arm32/pmap.c Sat Nov 8 08:01:34 2014
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.c,v 1.311 2014/11/07 12:44:58 skrll Exp $ */
+/* $NetBSD: pmap.c,v 1.312 2014/11/08 08:01:34 matt Exp $ */
/*
* Copyright 2003 Wasabi Systems, Inc.
@@ -215,7 +215,7 @@
#include <arm/locore.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.311 2014/11/07 12:44:58 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.312 2014/11/08 08:01:34 matt Exp $");
//#define PMAP_DEBUG
#ifdef PMAP_DEBUG
@@ -1282,13 +1282,18 @@ pmap_alloc_l1(pmap_t pm)
{
#ifdef ARM_MMU_EXTENDED
#ifdef __HAVE_MM_MD_DIRECT_MAPPED_PHYS
+ struct vm_page *pg;
+ bool ok __diagused;
+ for (;;) {
#ifdef PMAP_NEED_ALLOC_POOLPAGE
- struct vm_page *pg = arm_pmap_alloc_poolpage(UVM_PGA_ZERO);
+ pg = arm_pmap_alloc_poolpage(UVM_PGA_ZERO);
#else
- struct vm_page *pg = uvm_pagealloc(NULL, 0, NULL, UVM_PGA_ZERO);
+ pg = uvm_pagealloc(NULL, 0, NULL, UVM_PGA_ZERO);
#endif
- bool ok __diagused;
- KASSERT(pg != NULL);
+ if (pg != NULL)
+ break;
+ uvm_wait("pmapl1alloc");
+ }
pm->pm_l1_pa = VM_PAGE_TO_PHYS(pg);
vaddr_t va = pmap_direct_mapped_phys(pm->pm_l1_pa, &ok, 0);
KASSERT(ok);