percpu: fix pcpu_chunk_struct_size
authorTejun Heo <tj@kernel.org>
Tue, 24 Feb 2009 02:57:20 +0000 (11:57 +0900)
committerTejun Heo <tj@kernel.org>
Tue, 24 Feb 2009 02:57:20 +0000 (11:57 +0900)
Impact: fix short allocation leading to memory corruption

While dropping rvalue wrapping macros around global parameters,
pcpu_chunk_struct_size was set incorrectly resulting in shorter page
pointer array.  Fix it.

Signed-off-by: Tejun Heo <tj@kernel.org>
mm/percpu.c

index 997724c2ea24ceb403718549b0d703f964a36185..ed92caa2aa3bf5f5f03d133abb5b57c614d0e3d0 100644 (file)
@@ -850,7 +850,7 @@ size_t __init pcpu_setup_static(pcpu_populate_pte_fn_t populate_pte_fn,
        pcpu_chunk_size = num_possible_cpus() * pcpu_unit_size;
        pcpu_nr_slots = pcpu_size_to_slot(pcpu_unit_size) + 1;
        pcpu_chunk_struct_size = sizeof(struct pcpu_chunk)
-               + (1 << pcpu_unit_pages_shift) * sizeof(struct page *);
+               + num_possible_cpus() * pcpu_unit_pages * sizeof(struct page *);
 
        /* allocate chunk slots */
        pcpu_slot = alloc_bootmem(pcpu_nr_slots * sizeof(pcpu_slot[0]));