Subject: Re: ARM port organisation (was: Re: NetBSD/hpcarm snap code)
To: None <thorpej@zembu.com>
From: Richard Earnshaw <rearnsha@buzzard.freeserve.co.uk>
List: port-arm32
Date: 02/18/2001 00:08:49
> On Sat, Feb 17, 2001 at 06:47:39PM +0000, Richard Earnshaw wrote:
>
> > > Oh, yah, the WinCE hack -- I don't think we want to use that feature
> > > on the FCS-capable chips.
> >
> > On handhelds (like the Ipaq), this may be exactly what is wanted. On a
> > desktop machine I agree, it's unlikely to be of use because of the
> > restrictions it imposes.
>
> Well, 32M is a pretty small address space -- it's going to affect where
> you put the stack, is certainly going to affect shared libraries, etc.,
> and may constitute a new ABI.
>
> What would be really nice is if future ARM chips included *real* address
> space IDs (a'la MIPS).
With the normal layout, yes, it would be a tight fit (mainly because the
normal layout leaves a lot of large holes.
I don't know whether it's possible to achieve the following layout, but if
we can, and if the processor can cope with a process growing from sub-32M
to more than that (I haven't read the docs carefully enough to know), then
the following order might work.
0x00008000 prog base
top of prog data shared libs
0x017fffff stack top
0x01800000 heap base
0x02000000 small-proc limit
this would allow most procs to run within the limit with the proviso that
the stack does not grow down into the shared libs. Processes could grow
their heap to any size provided that they can move from being small to
large procs. The cpu can fast context switch from any small proc to any
other small proc, and only needs a cache flush if either old or new
process is a large proc. On the assumption that most processes will not
be large, this should make cache flushes for this reason quite rare.