diff options
author | Paul Mundt <lethal@linux-sh.org> | 2009-10-14 14:14:30 +0900 |
---|---|---|
committer | Paul Mundt <lethal@linux-sh.org> | 2009-10-14 15:44:12 +0900 |
commit | a66c2edea56c291a6f6a52f07496ebb97c0880e8 (patch) | |
tree | 8019cfb6ebcfbc676a6c08fba83a460f63edea61 /arch/sh | |
parent | 2908df9e2ce85e4de19ba81ac619acdf93a8bfaa (diff) | |
download | linux-a66c2edea56c291a6f6a52f07496ebb97c0880e8.tar.gz linux-a66c2edea56c291a6f6a52f07496ebb97c0880e8.tar.bz2 linux-a66c2edea56c291a6f6a52f07496ebb97c0880e8.zip |
sh: Populate initial secondary CPU info from boot_cpu_data.
The secondary CPU info was seeing corrupted results due to not entering
all of the setup paths taken by the boot CPU. So we just memcpy() the
boot cpu data over directly, and then fix up the per-CPU bits.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Diffstat (limited to 'arch/sh')
-rw-r--r-- | arch/sh/kernel/smp.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/sh/kernel/smp.c b/arch/sh/kernel/smp.c index 442d8d47a41e..160db1003cfb 100644 --- a/arch/sh/kernel/smp.c +++ b/arch/sh/kernel/smp.c @@ -35,6 +35,8 @@ static inline void __init smp_store_cpu_info(unsigned int cpu) { struct sh_cpuinfo *c = cpu_data + cpu; + memcpy(c, &boot_cpu_data, sizeof(struct sh_cpuinfo)); + c->loops_per_jiffy = loops_per_jiffy; } |