From a4513e9da8410de9807fcc5d2c2387629787ca6d Mon Sep 17 00:00:00 2001 From: pjd Date: Thu, 5 Apr 2007 20:52:51 +0000 Subject: When KVA is exhausted, try the vm_lowmem event for the last time before panicing. This helps a lot in ZFS stability. --- sys/vm/vm_kern.c | 18 ++++++++++++++---- 1 file changed, 14 insertions(+), 4 deletions(-) (limited to 'sys/vm') diff --git a/sys/vm/vm_kern.c b/sys/vm/vm_kern.c index b6a4738..fd01c4e 100644 --- a/sys/vm/vm_kern.c +++ b/sys/vm/vm_kern.c @@ -68,6 +68,7 @@ __FBSDID("$FreeBSD$"); #include #include #include /* for ticks and hz */ +#include #include #include #include @@ -81,6 +82,7 @@ __FBSDID("$FreeBSD$"); #include #include #include +#include vm_map_t kernel_map=0; vm_map_t kmem_map=0; @@ -294,10 +296,18 @@ kmem_malloc(map, size, flags) vm_map_lock(map); if (vm_map_findspace(map, vm_map_min(map), size, &addr)) { vm_map_unlock(map); - if ((flags & M_NOWAIT) == 0) - panic("kmem_malloc(%ld): kmem_map too small: %ld total allocated", - (long)size, (long)map->size); - return (0); + if ((flags & M_NOWAIT) == 0) { + EVENTHANDLER_INVOKE(vm_lowmem, 0); + uma_reclaim(); + vm_map_lock(map); + if (vm_map_findspace(map, vm_map_min(map), size, &addr)) { + vm_map_unlock(map); + panic("kmem_malloc(%ld): kmem_map too small: %ld total allocated", + (long)size, (long)map->size); + } + } else { + return (0); + } } offset = addr - VM_MIN_KERNEL_ADDRESS; vm_object_reference(kmem_object); -- cgit v1.1