Re: [RFC/PATCH] powerpc: Dynamically allocate pacas
From: Michael Neuling <hidden>
Date: 2010-01-27 03:10:44
On Fri, 2010-01-22 at 16:19 +1300, Michael Neuling wrote:quoted
=20 In message <39fb8f1aeab9940b86c940b9a5f8e6bd41ec316c.1263368253.git.micha=el@ellquoted
erman.id.au> you wrote:quoted
On 64-bit kernels we currently have a 512 byte struct paca_struct for each cpu (usually just called "the paca"). Currently they are staticall=yquoted
quoted
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. =20 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. =20 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. =20 Lightly booted on Legacy iSeries & pSeries LPAR.=20 This is broken on 32bit CPUs. Dies at compile time with mpc86xx_defconfig. No paca on 32bit :-(Bah, who really uses 32-bit anyway ..
Hehe, that's coming from the guy who tested it on iSeries... :-P Mikey