diff options
author | Kumar Gala <galak@freescale.com> | 2005-09-27 16:13:12 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2005-09-28 01:42:54 -0400 |
commit | 400d221274426958f1e1c7081a247bea9cede696 (patch) | |
tree | db0907bc14504d827b06b45004152b6610387b40 /arch/ppc/kernel | |
parent | 10b35d9978ac35556aec0d2642055742d8941488 (diff) |
[PATCH] ppc32: make cur_cpu_spec a single pointer instead of an array
Changed ppc32 so that cur_cpu_spec is just a single pointer for all CPUs.
Additionally, made call_setup_cpu check to see if the cpu_setup pointer
is NULL or not before calling the function. This lets remove the dummy
cpu_setup calls that just return.
Signed-off-by: Kumar Gala <kumar.gala@freescale.com>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/ppc/kernel')
-rw-r--r-- | arch/ppc/kernel/cpu_setup_6xx.S | 2 | ||||
-rw-r--r-- | arch/ppc/kernel/cpu_setup_power4.S | 2 | ||||
-rw-r--r-- | arch/ppc/kernel/cputable.c | 33 | ||||
-rw-r--r-- | arch/ppc/kernel/head.S | 6 | ||||
-rw-r--r-- | arch/ppc/kernel/misc.S | 22 | ||||
-rw-r--r-- | arch/ppc/kernel/setup.c | 14 |
6 files changed, 30 insertions, 49 deletions
diff --git a/arch/ppc/kernel/cpu_setup_6xx.S b/arch/ppc/kernel/cpu_setup_6xx.S index ba396438ede3..a5333c07fc3c 100644 --- a/arch/ppc/kernel/cpu_setup_6xx.S +++ b/arch/ppc/kernel/cpu_setup_6xx.S | |||
@@ -17,8 +17,6 @@ | |||
17 | #include <asm/asm-offsets.h> | 17 | #include <asm/asm-offsets.h> |
18 | #include <asm/cache.h> | 18 | #include <asm/cache.h> |
19 | 19 | ||
20 | _GLOBAL(__setup_cpu_601) | ||
21 | blr | ||
22 | _GLOBAL(__setup_cpu_603) | 20 | _GLOBAL(__setup_cpu_603) |
23 | b setup_common_caches | 21 | b setup_common_caches |
24 | _GLOBAL(__setup_cpu_604) | 22 | _GLOBAL(__setup_cpu_604) |
diff --git a/arch/ppc/kernel/cpu_setup_power4.S b/arch/ppc/kernel/cpu_setup_power4.S index 7e4fbb653724..0abb5f25b2ca 100644 --- a/arch/ppc/kernel/cpu_setup_power4.S +++ b/arch/ppc/kernel/cpu_setup_power4.S | |||
@@ -63,8 +63,6 @@ _GLOBAL(__970_cpu_preinit) | |||
63 | isync | 63 | isync |
64 | blr | 64 | blr |
65 | 65 | ||
66 | _GLOBAL(__setup_cpu_power4) | ||
67 | blr | ||
68 | _GLOBAL(__setup_cpu_ppc970) | 66 | _GLOBAL(__setup_cpu_ppc970) |
69 | mfspr r0,SPRN_HID0 | 67 | mfspr r0,SPRN_HID0 |
70 | li r11,5 /* clear DOZE and SLEEP */ | 68 | li r11,5 /* clear DOZE and SLEEP */ |
diff --git a/arch/ppc/kernel/cputable.c b/arch/ppc/kernel/cputable.c index 97663d5d96ca..207d4dd059d9 100644 --- a/arch/ppc/kernel/cputable.c +++ b/arch/ppc/kernel/cputable.c | |||
@@ -14,23 +14,22 @@ | |||
14 | #include <linux/sched.h> | 14 | #include <linux/sched.h> |
15 | #include <linux/threads.h> | 15 | #include <linux/threads.h> |
16 | #include <linux/init.h> | 16 | #include <linux/init.h> |
17 | #include <linux/module.h> | ||
18 | |||
19 | #include <asm/oprofile_impl.h> | ||
17 | #include <asm/cputable.h> | 20 | #include <asm/cputable.h> |
18 | 21 | ||
19 | struct cpu_spec* cur_cpu_spec[NR_CPUS]; | 22 | struct cpu_spec* cur_cpu_spec = NULL; |
20 | 23 | ||
21 | extern void __setup_cpu_601(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 24 | extern void __setup_cpu_603(unsigned long offset, struct cpu_spec* spec); |
22 | extern void __setup_cpu_603(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 25 | extern void __setup_cpu_604(unsigned long offset, struct cpu_spec* spec); |
23 | extern void __setup_cpu_604(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 26 | extern void __setup_cpu_750(unsigned long offset, struct cpu_spec* spec); |
24 | extern void __setup_cpu_750(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 27 | extern void __setup_cpu_750cx(unsigned long offset, struct cpu_spec* spec); |
25 | extern void __setup_cpu_750cx(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 28 | extern void __setup_cpu_750fx(unsigned long offset, struct cpu_spec* spec); |
26 | extern void __setup_cpu_750fx(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 29 | extern void __setup_cpu_7400(unsigned long offset, struct cpu_spec* spec); |
27 | extern void __setup_cpu_7400(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 30 | extern void __setup_cpu_7410(unsigned long offset, struct cpu_spec* spec); |
28 | extern void __setup_cpu_7410(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 31 | extern void __setup_cpu_745x(unsigned long offset, struct cpu_spec* spec); |
29 | extern void __setup_cpu_745x(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | 32 | extern void __setup_cpu_ppc970(unsigned long offset, struct cpu_spec* spec); |
30 | extern void __setup_cpu_power3(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | ||
31 | extern void __setup_cpu_power4(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | ||
32 | extern void __setup_cpu_ppc970(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | ||
33 | extern void __setup_cpu_generic(unsigned long offset, int cpu_nr, struct cpu_spec* spec); | ||
34 | 33 | ||
35 | #define CLASSIC_PPC (!defined(CONFIG_8xx) && !defined(CONFIG_4xx) && \ | 34 | #define CLASSIC_PPC (!defined(CONFIG_8xx) && !defined(CONFIG_4xx) && \ |
36 | !defined(CONFIG_POWER3) && !defined(CONFIG_POWER4) && \ | 35 | !defined(CONFIG_POWER3) && !defined(CONFIG_POWER4) && \ |
@@ -62,7 +61,6 @@ struct cpu_spec cpu_specs[] = { | |||
62 | PPC_FEATURE_UNIFIED_CACHE, | 61 | PPC_FEATURE_UNIFIED_CACHE, |
63 | .icache_bsize = 32, | 62 | .icache_bsize = 32, |
64 | .dcache_bsize = 32, | 63 | .dcache_bsize = 32, |
65 | .cpu_setup = __setup_cpu_601 | ||
66 | }, | 64 | }, |
67 | { /* 603 */ | 65 | { /* 603 */ |
68 | .pvr_mask = 0xffff0000, | 66 | .pvr_mask = 0xffff0000, |
@@ -451,7 +449,6 @@ struct cpu_spec cpu_specs[] = { | |||
451 | .cpu_user_features = COMMON_PPC, | 449 | .cpu_user_features = COMMON_PPC, |
452 | .icache_bsize = 32, | 450 | .icache_bsize = 32, |
453 | .dcache_bsize = 32, | 451 | .dcache_bsize = 32, |
454 | .cpu_setup = __setup_cpu_generic | ||
455 | }, | 452 | }, |
456 | #endif /* CLASSIC_PPC */ | 453 | #endif /* CLASSIC_PPC */ |
457 | #ifdef CONFIG_PPC64BRIDGE | 454 | #ifdef CONFIG_PPC64BRIDGE |
@@ -464,7 +461,6 @@ struct cpu_spec cpu_specs[] = { | |||
464 | .icache_bsize = 128, | 461 | .icache_bsize = 128, |
465 | .dcache_bsize = 128, | 462 | .dcache_bsize = 128, |
466 | .num_pmcs = 8, | 463 | .num_pmcs = 8, |
467 | .cpu_setup = __setup_cpu_power3 | ||
468 | }, | 464 | }, |
469 | { /* Power3+ */ | 465 | { /* Power3+ */ |
470 | .pvr_mask = 0xffff0000, | 466 | .pvr_mask = 0xffff0000, |
@@ -475,7 +471,6 @@ struct cpu_spec cpu_specs[] = { | |||
475 | .icache_bsize = 128, | 471 | .icache_bsize = 128, |
476 | .dcache_bsize = 128, | 472 | .dcache_bsize = 128, |
477 | .num_pmcs = 8, | 473 | .num_pmcs = 8, |
478 | .cpu_setup = __setup_cpu_power3 | ||
479 | }, | 474 | }, |
480 | { /* I-star */ | 475 | { /* I-star */ |
481 | .pvr_mask = 0xffff0000, | 476 | .pvr_mask = 0xffff0000, |
@@ -486,7 +481,6 @@ struct cpu_spec cpu_specs[] = { | |||
486 | .icache_bsize = 128, | 481 | .icache_bsize = 128, |
487 | .dcache_bsize = 128, | 482 | .dcache_bsize = 128, |
488 | .num_pmcs = 8, | 483 | .num_pmcs = 8, |
489 | .cpu_setup = __setup_cpu_power3 | ||
490 | }, | 484 | }, |
491 | { /* S-star */ | 485 | { /* S-star */ |
492 | .pvr_mask = 0xffff0000, | 486 | .pvr_mask = 0xffff0000, |
@@ -497,7 +491,6 @@ struct cpu_spec cpu_specs[] = { | |||
497 | .icache_bsize = 128, | 491 | .icache_bsize = 128, |
498 | .dcache_bsize = 128, | 492 | .dcache_bsize = 128, |
499 | .num_pmcs = 8, | 493 | .num_pmcs = 8, |
500 | .cpu_setup = __setup_cpu_power3 | ||
501 | }, | 494 | }, |
502 | #endif /* CONFIG_PPC64BRIDGE */ | 495 | #endif /* CONFIG_PPC64BRIDGE */ |
503 | #ifdef CONFIG_POWER4 | 496 | #ifdef CONFIG_POWER4 |
diff --git a/arch/ppc/kernel/head.S b/arch/ppc/kernel/head.S index d05509f197d0..8cdac7385e7f 100644 --- a/arch/ppc/kernel/head.S +++ b/arch/ppc/kernel/head.S | |||
@@ -1059,7 +1059,6 @@ __secondary_start: | |||
1059 | 1059 | ||
1060 | lis r3,-KERNELBASE@h | 1060 | lis r3,-KERNELBASE@h |
1061 | mr r4,r24 | 1061 | mr r4,r24 |
1062 | bl identify_cpu | ||
1063 | bl call_setup_cpu /* Call setup_cpu for this CPU */ | 1062 | bl call_setup_cpu /* Call setup_cpu for this CPU */ |
1064 | #ifdef CONFIG_6xx | 1063 | #ifdef CONFIG_6xx |
1065 | lis r3,-KERNELBASE@h | 1064 | lis r3,-KERNELBASE@h |
@@ -1109,11 +1108,6 @@ __secondary_start: | |||
1109 | * Those generic dummy functions are kept for CPUs not | 1108 | * Those generic dummy functions are kept for CPUs not |
1110 | * included in CONFIG_6xx | 1109 | * included in CONFIG_6xx |
1111 | */ | 1110 | */ |
1112 | _GLOBAL(__setup_cpu_power3) | ||
1113 | blr | ||
1114 | _GLOBAL(__setup_cpu_generic) | ||
1115 | blr | ||
1116 | |||
1117 | #if !defined(CONFIG_6xx) && !defined(CONFIG_POWER4) | 1111 | #if !defined(CONFIG_6xx) && !defined(CONFIG_POWER4) |
1118 | _GLOBAL(__save_cpu_setup) | 1112 | _GLOBAL(__save_cpu_setup) |
1119 | blr | 1113 | blr |
diff --git a/arch/ppc/kernel/misc.S b/arch/ppc/kernel/misc.S index 9d2cb79475c6..2b9a16274b0b 100644 --- a/arch/ppc/kernel/misc.S +++ b/arch/ppc/kernel/misc.S | |||
@@ -125,9 +125,8 @@ _GLOBAL(identify_cpu) | |||
125 | 1: | 125 | 1: |
126 | addis r6,r3,cur_cpu_spec@ha | 126 | addis r6,r3,cur_cpu_spec@ha |
127 | addi r6,r6,cur_cpu_spec@l | 127 | addi r6,r6,cur_cpu_spec@l |
128 | slwi r4,r4,2 | ||
129 | sub r8,r8,r3 | 128 | sub r8,r8,r3 |
130 | stwx r8,r4,r6 | 129 | stw r8,0(r6) |
131 | blr | 130 | blr |
132 | 131 | ||
133 | /* | 132 | /* |
@@ -186,19 +185,18 @@ _GLOBAL(do_cpu_ftr_fixups) | |||
186 | * | 185 | * |
187 | * Setup function is called with: | 186 | * Setup function is called with: |
188 | * r3 = data offset | 187 | * r3 = data offset |
189 | * r4 = CPU number | 188 | * r4 = ptr to CPU spec (relocated) |
190 | * r5 = ptr to CPU spec (relocated) | ||
191 | */ | 189 | */ |
192 | _GLOBAL(call_setup_cpu) | 190 | _GLOBAL(call_setup_cpu) |
193 | addis r5,r3,cur_cpu_spec@ha | 191 | addis r4,r3,cur_cpu_spec@ha |
194 | addi r5,r5,cur_cpu_spec@l | 192 | addi r4,r4,cur_cpu_spec@l |
195 | slwi r4,r24,2 | 193 | lwz r4,0(r4) |
196 | lwzx r5,r4,r5 | 194 | add r4,r4,r3 |
195 | lwz r5,CPU_SPEC_SETUP(r4) | ||
196 | cmpi 0,r5,0 | ||
197 | add r5,r5,r3 | 197 | add r5,r5,r3 |
198 | lwz r6,CPU_SPEC_SETUP(r5) | 198 | beqlr |
199 | add r6,r6,r3 | 199 | mtctr r5 |
200 | mtctr r6 | ||
201 | mr r4,r24 | ||
202 | bctr | 200 | bctr |
203 | 201 | ||
204 | #if defined(CONFIG_CPU_FREQ_PMAC) && defined(CONFIG_6xx) | 202 | #if defined(CONFIG_CPU_FREQ_PMAC) && defined(CONFIG_6xx) |
diff --git a/arch/ppc/kernel/setup.c b/arch/ppc/kernel/setup.c index 1b891b806f3d..62022eacf63e 100644 --- a/arch/ppc/kernel/setup.c +++ b/arch/ppc/kernel/setup.c | |||
@@ -188,18 +188,18 @@ int show_cpuinfo(struct seq_file *m, void *v) | |||
188 | seq_printf(m, "processor\t: %d\n", i); | 188 | seq_printf(m, "processor\t: %d\n", i); |
189 | seq_printf(m, "cpu\t\t: "); | 189 | seq_printf(m, "cpu\t\t: "); |
190 | 190 | ||
191 | if (cur_cpu_spec[i]->pvr_mask) | 191 | if (cur_cpu_spec->pvr_mask) |
192 | seq_printf(m, "%s", cur_cpu_spec[i]->cpu_name); | 192 | seq_printf(m, "%s", cur_cpu_spec->cpu_name); |
193 | else | 193 | else |
194 | seq_printf(m, "unknown (%08x)", pvr); | 194 | seq_printf(m, "unknown (%08x)", pvr); |
195 | #ifdef CONFIG_ALTIVEC | 195 | #ifdef CONFIG_ALTIVEC |
196 | if (cur_cpu_spec[i]->cpu_features & CPU_FTR_ALTIVEC) | 196 | if (cur_cpu_spec->cpu_features & CPU_FTR_ALTIVEC) |
197 | seq_printf(m, ", altivec supported"); | 197 | seq_printf(m, ", altivec supported"); |
198 | #endif | 198 | #endif |
199 | seq_printf(m, "\n"); | 199 | seq_printf(m, "\n"); |
200 | 200 | ||
201 | #ifdef CONFIG_TAU | 201 | #ifdef CONFIG_TAU |
202 | if (cur_cpu_spec[i]->cpu_features & CPU_FTR_TAU) { | 202 | if (cur_cpu_spec->cpu_features & CPU_FTR_TAU) { |
203 | #ifdef CONFIG_TAU_AVERAGE | 203 | #ifdef CONFIG_TAU_AVERAGE |
204 | /* more straightforward, but potentially misleading */ | 204 | /* more straightforward, but potentially misleading */ |
205 | seq_printf(m, "temperature \t: %u C (uncalibrated)\n", | 205 | seq_printf(m, "temperature \t: %u C (uncalibrated)\n", |
@@ -754,12 +754,12 @@ void __init setup_arch(char **cmdline_p) | |||
754 | * for a possibly more accurate value. | 754 | * for a possibly more accurate value. |
755 | */ | 755 | */ |
756 | if (cpu_has_feature(CPU_FTR_SPLIT_ID_CACHE)) { | 756 | if (cpu_has_feature(CPU_FTR_SPLIT_ID_CACHE)) { |
757 | dcache_bsize = cur_cpu_spec[0]->dcache_bsize; | 757 | dcache_bsize = cur_cpu_spec->dcache_bsize; |
758 | icache_bsize = cur_cpu_spec[0]->icache_bsize; | 758 | icache_bsize = cur_cpu_spec->icache_bsize; |
759 | ucache_bsize = 0; | 759 | ucache_bsize = 0; |
760 | } else | 760 | } else |
761 | ucache_bsize = dcache_bsize = icache_bsize | 761 | ucache_bsize = dcache_bsize = icache_bsize |
762 | = cur_cpu_spec[0]->dcache_bsize; | 762 | = cur_cpu_spec->dcache_bsize; |
763 | 763 | ||
764 | /* reboot on panic */ | 764 | /* reboot on panic */ |
765 | panic_timeout = 180; | 765 | panic_timeout = 180; |