From owner-cvs-all Wed Nov 6 11:32:32 2002 Delivered-To: cvs-all@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id B5D4E37B401; Wed, 6 Nov 2002 11:32:30 -0800 (PST) Received: from critter.freebsd.dk (critter.freebsd.dk [212.242.86.163]) by mx1.FreeBSD.org (Postfix) with ESMTP id B188B43E6E; Wed, 6 Nov 2002 11:32:29 -0800 (PST) (envelope-from phk@critter.freebsd.dk) Received: from critter.freebsd.dk (localhost [127.0.0.1]) by critter.freebsd.dk (8.12.6/8.12.6) with ESMTP id gA6JWCB6006000; Wed, 6 Nov 2002 20:32:12 +0100 (CET) (envelope-from phk@critter.freebsd.dk) To: Jeff Roberson Cc: cvs-committers@FreeBSD.org, cvs-all@FreeBSD.org Subject: Re: cvs commit: src/sys/sys malloc.h src/sys/kern kern_malloc.c In-Reply-To: Your message of "Wed, 06 Nov 2002 14:16:00 EST." <20021106141427.J1374-100000@mail.chesapeake.net> Date: Wed, 06 Nov 2002 20:32:12 +0100 Message-ID: <5999.1036611132@critter.freebsd.dk> From: Poul-Henning Kamp Sender: owner-cvs-all@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG In message <20021106141427.J1374-100000@mail.chesapeake.net>, Jeff Roberson wri tes: >> Log: >> Introduce malloc_last_fail() which returns the number of seconds since >> malloc(9) failed last time. This is intended to help code adjust >> memory usage to the current circumstances. >> >> A typical use could be: >> if (malloc_last_fail() < 60) >> reduce_cache_by_one(); > >I would like to add a 'flush' callback to uma. So each zone could get a >callback when the system is low on memory and it could reduce it's memory >footprint. This would be very effective for something like the vnode >cache or the directory cache, etc. > >What do you think of this? It would be trivial to add. I thought about it and then about the locking issues it might raise and then I thought "I'll let another mad-man try that" :-) Seriously, yes, I've actually wanted something like that for years, not only for the kernel but for userland as well. For the kernel, it will obviously have to be "best effort" and if the necessary locks are unavailable we have to punt. For userland I would like a "SIGVM" which says "spare a page". To be effective, this signal should _not_ result in a process to become runnable if it currently sleeps, rather, it should only be delivered when the process gets runnable for some other reason. -- Poul-Henning Kamp | UNIX since Zilog Zeus 3.20 phk@FreeBSD.ORG | TCP/IP since RFC 956 FreeBSD committer | BSD since 4.3-tahoe Never attribute to malice what can adequately be explained by incompetence. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe cvs-all" in the body of the message