Skip site navigation (1)Skip section navigation (2)
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>