Safer nr_node_ids and nr_node_ids determination and initial values
commit476f35348eb8d2a827765992899fea78b7dcc46f
authorChristoph Lameter <clameter@engr.sgi.com>
Sun, 6 May 2007 21:48:58 +0000 (6 14:48 -0700)
committerLinus Torvalds <torvalds@woody.linux-foundation.org>
Mon, 7 May 2007 19:12:51 +0000 (7 12:12 -0700)
tree81dbace9de3d4ffa3ecc67bffe265134962117bd
parentaee16b3cee2746880e40945a9b5bff4f309cfbc4
Safer nr_node_ids and nr_node_ids determination and initial values

The nr_cpu_ids value is currently only calculated in smp_init.  However, it
may be needed before (SLUB needs it on kmem_cache_init!) and other kernel
components may also want to allocate dynamically sized per cpu array before
smp_init.  So move the determination of possible cpus into sched_init()
where we already loop over all possible cpus early in boot.

Also initialize both nr_node_ids and nr_cpu_ids with the highest value they
could take.  If we have accidental users before these values are determined
then the current valud of 0 may cause too small per cpu and per node arrays
to be allocated.  If it is set to the maximum possible then we only waste
some memory for early boot users.

Signed-off-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
init/main.c
kernel/sched.c
lib/cpumask.c
mm/page_alloc.c