public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: Terry Barnaby <terry1@beam.ltd.uk>
To: davids@webmaster.com
Cc: Mike Black <mblack@csi-inc.com>, linux-kernel@vger.kernel.org
Subject: Re: Problem with mlockall() and Threads: memory usage
Date: Wed, 19 May 2004 09:45:27 +0100	[thread overview]
Message-ID: <40AB1EA7.8080104@beam.ltd.uk> (raw)
In-Reply-To: <MDEHLPKNGKAHNMBLJOLKEEIJMBAA.davids@webmaster.com>

Hi David,

We do want improved latency, but with reasonable memory usage. This is
a soft real-time system. At the moment the memory usage is far too high in
our application.

With 20 threads runing the system will lock 160MBytes of memory just for stack
space (8 MBytes each), although the application probably only needs 2MByte in
total.
We can reduce the maximum stack size per thread, but then if a thread
increases its stack size beyond this the application will crash with a
segment fault, not good ...

For our use, mapping in physical memory as required for a growing stack would be
a good compromise between latency and memory usage. Once the system has run the
worker threads for a short time all of the needed stack memory will be locked in
and latency will be controlled. If a thread needs more memory for stack in a particular
instance, there will be a latency hit but this would be acceptable and
much better than a crash.

Terry

David Schwartz wrote:
>>Thanks for that.
>>I have done some more investigating, and on my system (Standard RedHat 9)
>>the stack ulimit is set to 8192 KBytes. So it appears that the thread
>>library/kernel threads pre-allocates, and writes to, 8129 KBytes
>>of stack per
>>thread and so then mlockall() locks all of this in memory.
>>
>>Should'nt the Thread library grow the stack rather than
>>preallocate it all even
>>with mlockall() like malloc ?
> 
> 
> 	I thought you wanted improved latency. Surely having to find a page for you
> when your stack grows will add unpredictable latency. So, no, the thread
> library should reserve the stack when 'mlockall(MCL_FUTURE)' is specified.
> 
> 	I do agree that having an 'initial stack size' in additional to a 'maximum
> stack size' would be a good idea. The former good for application that are
> concerned about physical memory usage and the latter for applications
> concerned about virtual memory usage.
> 
> 	DS
> 
> 
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at  http://www.tux.org/lkml/
> 

-- 
Dr Terry Barnaby                     BEAM Ltd
Phone: +44 1454 324512               Northavon Business Center, Dean Rd
Fax:   +44 1454 313172               Yate, Bristol, BS37 5NH, UK
Email: terry@beam.ltd.uk             Web: www.beam.ltd.uk
BEAM for: Visually Impaired X-Terminals, Parallel Processing, Software
                       "Tandems are twice the fun !"

  reply	other threads:[~2004-05-19  8:45 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-05-18 10:10 Problem with mlockall() and Threads: memory usage Terry Barnaby
     [not found] ` <041501c43cc9$28aaed00$c8de11cc@black>
2004-05-18 12:51   ` Terry Barnaby
2004-05-18 20:38     ` David Schwartz
2004-05-19  8:45       ` Terry Barnaby [this message]
2004-05-20  0:23         ` Elladan
2004-05-21 14:28           ` Terry Barnaby
2004-05-21 14:28           ` Terry Barnaby

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=40AB1EA7.8080104@beam.ltd.uk \
    --to=terry1@beam.ltd.uk \
    --cc=davids@webmaster.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mblack@csi-inc.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox