Subject: Re: metadata cache and memory fragmentation
To: Thor Lancelot Simon <firstname.lastname@example.org>
From: Daniel Carosone <email@example.com>
Date: 05/14/2004 10:14:29
Content-Type: text/plain; charset=us-ascii
On Thu, May 13, 2004 at 11:48:50AM -0400, Thor Lancelot Simon wrote:
> The interaction of the new metadata cache and the page cache seems to lead
> to significant kernel memory fragmentation. Because most requests from
> the metadata cache are small, larger regions of free memory are split up;
> when the metadata cache returns memory, it does so one buffer at a time
> (typically just one or two pages) and this means that even when we have
> quite a bit of memory free, very little of it may be contiguous. This
> causes problems for drivers like the USB drivers and the drivers for
> various cardbus cards.
> As an experiment, if you're having "can't allocate..." problems with
> such a driver, try removing the device in question, reducing
> vm.bufmem_hiwater significantly, and running something that allocates,
> then frees a good-zies hunk of memory. You will probably then find that
> you can reconnect the device and everything will work fine.
I find this works even without needing to bash the sysctl:
dd if=3D/dev/zero of=3D/dev/null bs=3D<about 3/4 of ram size> count=3D2
> I'm not sure how to address this issue. I'd love to hear ideas.
It might be that a statistical approach is enough to help out;
something like malloc hints that could bias allocations for the page
cache to higher addresses and bufcache to lower addresses?
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.2.4 (NetBSD)
-----END PGP SIGNATURE-----