Date: Fri, 22 Jan 1999 11:53:25 -0800 (PST) From: Matthew Dillon <dillon@apollo.backplane.com> To: "John S. Dyson" <dyson@iquest.net> Cc: hackers@FreeBSD.ORG Subject: Re: Error in vm_fault change Message-ID: <199901221953.LAA56414@apollo.backplane.com> References: <199901221749.MAA03968@y.dyson.net>
next in thread | previous in thread | raw e-mail | index | archive | help
Basically what it comes down to is that I do not think it is appropriate for there to be hacks all around the kernel to arbitrarily block processes in low memory situations. At the very worst, those same 'blockages' could be implemented in one place - the memory allocator, and nowhere else. But we can do much better. I like your RLIMIT_RSS code, but it isn't enough and I think it is implemented in the wrong place. I believe the correct place to implement the 'memory scheduler' is in vm_page_alloc() and vm_wait(). vm_page_alloc() uses some algorithm X ( which could simply be the RSS check ) to determine whether to return NULL or not for VM_ALLOC_NORMAL or VM_ALLOC_ZERO requests. vm_wait() ould implement the RSS enforcement as well as other sophistication. For example, it could determine that the enforcement is insufficient and start scaling it, or it could determine that the system is thrashing and implement a more sophisticated swap/sleep strategy. We can play with the scheduling and enforcement algorithms much more easily this way, too. What do you say ? -Matt To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?199901221953.LAA56414>