Date: Tue, 15 Apr 2008 13:19:58 +0100 (BST) From: Robert Watson <rwatson@FreeBSD.org> To: Andrew Reilly <andrew-freebsd@areilly.bpc-users.org> Cc: Roman Divacky <rdivacky@FreeBSD.org>, Julian Elischer <julian@elischer.org>, FreeBSD Current <current@FreeBSD.org> Subject: Re: stack hogs in kernel Message-ID: <20080415131712.Q29682@fledge.watson.org> In-Reply-To: <20080415034343.GB87024@duncan.reilly.home> References: <48002444.4030505@elischer.org> <20080412191300.E7693@fledge.watson.org> <20080412181601.GA14472@freebsd.org> <20080415034343.GB87024@duncan.reilly.home>
next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, 15 Apr 2008, Andrew Reilly wrote: > Why are single-digit kilobytes of memory space interesting, in this context? > Is the concern about L1 data cache footprint, for performance reasons? If > that is the case, the MAXPATHLEN bufffer will only really occupy the amount > of cache actually touched. > > I've long wondered about the seemingly fanatical stack size concern in > kernel space. In other domains (where I have more experience) you can get > good performance benefits from the essentially free memory management and > good cache re-use that comes from putting as much into the stack/call-frame > as possible. In addition to the valid points others have replied with (use of KVA, often not swappable, etc), it's worth noting that as with file descriptors, vnodes, sockets, inodes, etc, kernel thread size directly affects overall kernel scalability, as we require one kernel thread for each user thread in the system. If you have 4000 user threads, you have 4000 (plus change) kernel threads, so avoiding statically allocating large quantities of effectively unused memory can significantly improve memory pressure, especially on relatively small systems. Robert N M Watson Computer Laboratory University of Cambridge
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080415131712.Q29682>