Re: sbrk(2) broken

From: Giorgos Keramidas <keramida_at_ceid.upatras.gr>
Date: Sat, 5 Jan 2008 05:26:47 +0200
On 2008-01-04 11:18, Igor Mozolevsky <igor_at_hybrid-lab.co.uk> wrote:
> On 04/01/2008, Dag-Erling Sm?rgrav <des_at_des.no> wrote:
> > Of course, if you're afraid of memory overcommit and you know in advance
> > how much memory you need, you can simply allocate a sufficient amount of
> > address space at startup and touch it all.  This way, you will either be
> > killed right away, or be guaranteed to have sufficient memory for the
> > rest of your (process) lifetime.  Alternatively, do what Varnish does:
> > create a large file, mmap it, and allocate everything you need from that
> > area, so you have your own private swap space.  Just make sure to
> > actually allocate the disk space you need (by filling the file with
> > zeroes, or at the minimum writing a zero to the file every sb.st_blksize
> > bytes, preferably sequentially to avoid excessive fragmentation)
>
> Surely you can just fseek() on the file at the correct lenght?

That would create a nicely sized 'hole' in the starting blocks.  What
Dag-Erling describes is the correct(TM) way of making sure that all
blocks have been allocated from the backing store of the file.
Received on Sat Jan 05 2008 - 02:44:02 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:39:25 UTC