Date: Thu, 18 Jan 2007 16:08:21 -0800 From: Jason Evans <jasone@FreeBSD.org> To: Stefan Ehmann <shoesoft@gmx.net> Cc: freebsd-current@freebsd.org Subject: Re: very high memory usage in -current Message-ID: <45B00BF5.6030200@FreeBSD.org> In-Reply-To: <200701172045.35137.shoesoft@gmx.net> References: <200701172045.35137.shoesoft@gmx.net>
next in thread | previous in thread | raw e-mail | index | archive | help
Stefan Ehmann wrote: > [huge jpeg/png images cause memory bloat with konqueror and gtk apps, on -CURRENT.] > > I don't really know what's causing this problem. Maybe it's related to > jemalloc, but I'd be surprised if no one else has noticed this before. > > size/res values reported by top > > 6.2 desktop pc with nvidia binary driver > konqueror 40M/30M > > CURRENT notebook with the i810 driver > konqueror 290M/250M > > Any clues or more information needed? If you think jemalloc is involved, the easiest way to check is by reverting src/lib/libc/stdlib/malloc.c to revision 1.92, which is phkmalloc. If this substantially changes memory usage, then there are further diagnostics that can be used to help understand the issue. ----- If jemalloc is involved, here's what could cause such behavior. First, you would have to be running on a 32-bit platform, so that sbrk() is in use (rather than pure mmap() as for the 64-bit platforms). 1) The application would allocate some large chunks of memory for image processing. These data would be allocated in the data segment. 2) The application would allocate some additional long-lived object for which no existing memory region could be recycled. This would cause the object to be allocated in the data segment, at the end of the sbrk()ed memory. 3) The application would free most/all of the memory that was used for image processing. Unfortunately, due to the long-lived object from step (2), this would be in the middle of the sbrk()ed memory, and so malloc would have to hold onto the memory for possible future use, unable to return it to the kernel. The right solution to the problem is to get rid of the hard line between data segment and heap, and use the address space that is currently reserved for sbrk() as the last resort for mmap() requests, thus allowing the data segment and heap to gracefully grow toward each other until memory is exhausted. We really don't need the data segment anymore except for legacy support of applications that do their own memory management via sbrk(). However, when I talked with the VM wizards, I was sufficiently intimidated by the difficulty of removing the hard-coded data segment size that I did not pursue it any further. Personally, in the absence of a dynamic boundary between the data segment and the heap, I would be quite happy to completely disable sbrk() support in jemalloc, and let those who really need that last 512 MB of address space adjust resource limits for their applications as necessary. In practice, I expect this would cause people far less trouble than does the current state of affairs. Jason
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?45B00BF5.6030200>