[RFC/PATCH] powerpc: Dynamically allocate pacas
Michael Ellerman
michael at ellerman.id.au
Thu Jan 14 11:30:42 EST 2010
On Thu, 2010-01-14 at 11:26 +1100, Michael Neuling wrote:
> > On 64-bit kernels we currently have a 512 byte struct paca_struct for
> > each cpu (usually just called "the paca"). Currently they are statically
> > allocated, which means a kernel built for a large number of cpus will
> > waste a lot of space if it's booted on a machine with few cpus.
> >
> > We can avoid that by only allocating the number of pacas we need at
> > boot. However this is complicated by the fact that we need to access
> > the paca before we know how many cpus there are in the system.
> >
> > The solution is to dynamically allocate enough space for NR_CPUS pacas,
> > but then later in boot when we know how many cpus we have, we free any
> > unused pacas.
> >
> > Lightly booted on Legacy iSeries & pSeries LPAR.
> >
> > Signed-off-by: Michael Ellerman <michael at ellerman.id.au>
>
> Nice!
>
> <snip>
>
> > + lmb_free(__pa(paca) + new_size, paca_size - new_size);
>
> You didn't explicitly mention this above but this depends on your
> lmb_free patch...
Ah yes, good point :)
> FYI boots bare metal
Sweet! Thanks for testing.
cheers
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 197 bytes
Desc: This is a digitally signed message part
URL: <http://lists.ozlabs.org/pipermail/linuxppc-dev/attachments/20100114/48a12bc0/attachment.pgp>
More information about the Linuxppc-dev
mailing list