Graceful failure instead of panicking in kmem_malloc
Joshua Isom
jrisom at gmail.com
Wed Jan 9 01:53:09 PST 2008
On Jan 8, 2008, at 9:25 PM, Bharma Ji wrote:
> Thanks for the response. I am hoping to keep some memory aside
> specifically
> for handling out of memory allocation situations. Yes the real fix is
> to
> avoid out of memory allocation. Thanks for the patch. Will try that.
> As a
> first cut I am just trying to handle failure gracefully.
>
> So asking again - if there is any way already discussed or
> standardized to
> make the system handle failures gracefully
>
> On Jan 8, 2008 4:30 PM, Kris Kennaway <kris at freebsd.org> wrote:
>
>> Bharma Ji wrote:
>>> In FreeBSD 6_2, if kmem_malloc is unable to find space it panics. The
>>> relevant code is in vm_kern.c
>>> if ((flags & M_NOWAIT) == 0)
>>> panic("kmem_malloc(%ld): kmem_map too small:
>> %ld
>>> total allocated",
>>> (long)size, (long)map->size);
>>>
>>> Is there any way to make the system log and then gracefully shut off
>> instead
>>> of panicking?
>>
>> Not really, because those actions require memory allocation. The real
>> fix is to either
>>
>> a) avoid running out of memory in the first place by tuning
>> vm.kmem_size
>>
>> b) perhaps trying harder to avoid panicking by first trying to more
>> aggressively reclaim memory.
>>
>> You can try
>>
>>
>> http://www.freebsd.org/~pjd/patches/vm_kern.c.2.patch<http://
>> www.freebsd.org/%7Epjd/patches/vm_kern.c.2.patch>
>>
>> which implements b) (patch against 7.0, but might apply to 6.2
>> unchanged).
>>
>> Kris
>>
> _______________________________________________
> freebsd-hackers at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
> To unsubscribe, send any mail to
> "freebsd-hackers-unsubscribe at freebsd.org"
Why not try to take out some user processes? Going with a combination
of process priority and memory usage, it should at least be more
tolerable than a panic.
More information about the freebsd-hackers
mailing list