|
@@ -0,0 +1,135 @@
|
|
|
+http://lkml.indiana.edu/hypermail/linux/kernel/1105.3/02199.html
|
|
|
+
|
|
|
+diff -Nur linux-2.6.39.orig/arch/mips/include/asm/smp-ops.h linux-2.6.39/arch/mips/include/asm/smp-ops.h
|
|
|
+--- linux-2.6.39.orig/arch/mips/include/asm/smp-ops.h 2011-05-19 06:06:34.000000000 +0200
|
|
|
++++ linux-2.6.39/arch/mips/include/asm/smp-ops.h 2011-08-29 04:39:03.360480881 +0200
|
|
|
+@@ -56,8 +56,43 @@
|
|
|
+
|
|
|
+ #endif /* !CONFIG_SMP */
|
|
|
+
|
|
|
+-extern struct plat_smp_ops up_smp_ops;
|
|
|
+-extern struct plat_smp_ops cmp_smp_ops;
|
|
|
+-extern struct plat_smp_ops vsmp_smp_ops;
|
|
|
++static inline int register_up_smp_ops(void)
|
|
|
++{
|
|
|
++#ifdef CONFIG_SMP_UP
|
|
|
++ extern struct plat_smp_ops up_smp_ops;
|
|
|
++
|
|
|
++ register_smp_ops(&up_smp_ops);
|
|
|
++
|
|
|
++ return 0;
|
|
|
++#else
|
|
|
++ return -ENODEV;
|
|
|
++#endif
|
|
|
++}
|
|
|
++
|
|
|
++static inline int register_cmp_smp_ops(void)
|
|
|
++{
|
|
|
++#ifdef CONFIG_MIPS_CMP
|
|
|
++ extern struct plat_smp_ops cmp_smp_ops;
|
|
|
++
|
|
|
++ register_smp_ops(&cmp_smp_ops);
|
|
|
++
|
|
|
++ return 0;
|
|
|
++#else
|
|
|
++ return -ENODEV;
|
|
|
++#endif
|
|
|
++}
|
|
|
++
|
|
|
++static inline int register_vsmp_smp_ops(void)
|
|
|
++{
|
|
|
++#ifdef CONFIG_MIPS_MT_SMP
|
|
|
++ extern struct plat_smp_ops vsmp_smp_ops;
|
|
|
++
|
|
|
++ register_smp_ops(&vsmp_smp_ops);
|
|
|
++
|
|
|
++ return 0;
|
|
|
++#else
|
|
|
++ return -ENODEV;
|
|
|
++#endif
|
|
|
++}
|
|
|
+
|
|
|
+ #endif /* __ASM_SMP_OPS_H */
|
|
|
+diff -Nur linux-2.6.39.orig/arch/mips/mipssim/sim_setup.c linux-2.6.39/arch/mips/mipssim/sim_setup.c
|
|
|
+--- linux-2.6.39.orig/arch/mips/mipssim/sim_setup.c 2011-05-19 06:06:34.000000000 +0200
|
|
|
++++ linux-2.6.39/arch/mips/mipssim/sim_setup.c 2011-08-29 04:39:03.390480572 +0200
|
|
|
+@@ -59,18 +59,17 @@
|
|
|
+
|
|
|
+ prom_meminit();
|
|
|
+
|
|
|
+-#ifdef CONFIG_MIPS_MT_SMP
|
|
|
+- if (cpu_has_mipsmt)
|
|
|
+- register_smp_ops(&vsmp_smp_ops);
|
|
|
+- else
|
|
|
+- register_smp_ops(&up_smp_ops);
|
|
|
+-#endif
|
|
|
++ if (cpu_has_mipsmt) {
|
|
|
++ if (!register_vsmp_smp_ops())
|
|
|
++ return;
|
|
|
++
|
|
|
+ #ifdef CONFIG_MIPS_MT_SMTC
|
|
|
+- if (cpu_has_mipsmt)
|
|
|
+ register_smp_ops(&ssmtc_smp_ops);
|
|
|
+- else
|
|
|
+- register_smp_ops(&up_smp_ops);
|
|
|
++ return;
|
|
|
+ #endif
|
|
|
++ }
|
|
|
++
|
|
|
++ register_up_smp_ops();
|
|
|
+ }
|
|
|
+
|
|
|
+ static void __init serial_init(void)
|
|
|
+diff -Nur linux-2.6.39.orig/arch/mips/mti-malta/malta-init.c linux-2.6.39/arch/mips/mti-malta/malta-init.c
|
|
|
+--- linux-2.6.39.orig/arch/mips/mti-malta/malta-init.c 2011-05-19 06:06:34.000000000 +0200
|
|
|
++++ linux-2.6.39/arch/mips/mti-malta/malta-init.c 2011-08-29 04:39:03.700480601 +0200
|
|
|
+@@ -29,6 +29,7 @@
|
|
|
+ #include <asm/system.h>
|
|
|
+ #include <asm/cacheflush.h>
|
|
|
+ #include <asm/traps.h>
|
|
|
++#include <asm/smp-ops.h>
|
|
|
+
|
|
|
+ #include <asm/gcmpregs.h>
|
|
|
+ #include <asm/mips-boards/prom.h>
|
|
|
+@@ -358,15 +359,14 @@
|
|
|
+ #ifdef CONFIG_SERIAL_8250_CONSOLE
|
|
|
+ console_config();
|
|
|
+ #endif
|
|
|
+-#ifdef CONFIG_MIPS_CMP
|
|
|
+ /* Early detection of CMP support */
|
|
|
+ if (gcmp_probe(GCMP_BASE_ADDR, GCMP_ADDRSPACE_SZ))
|
|
|
+- register_smp_ops(&cmp_smp_ops);
|
|
|
+- else
|
|
|
+-#endif
|
|
|
+-#ifdef CONFIG_MIPS_MT_SMP
|
|
|
+- register_smp_ops(&vsmp_smp_ops);
|
|
|
+-#endif
|
|
|
++ if (!register_cmp_smp_ops())
|
|
|
++ return;
|
|
|
++
|
|
|
++ if (!register_vsmp_smp_ops())
|
|
|
++ return;
|
|
|
++
|
|
|
+ #ifdef CONFIG_MIPS_MT_SMTC
|
|
|
+ register_smp_ops(&msmtc_smp_ops);
|
|
|
+ #endif
|
|
|
+diff -Nur linux-2.6.39.orig/arch/mips/pmc-sierra/msp71xx/msp_setup.c linux-2.6.39/arch/mips/pmc-sierra/msp71xx/msp_setup.c
|
|
|
+--- linux-2.6.39.orig/arch/mips/pmc-sierra/msp71xx/msp_setup.c 2011-05-19 06:06:34.000000000 +0200
|
|
|
++++ linux-2.6.39/arch/mips/pmc-sierra/msp71xx/msp_setup.c 2011-08-29 04:39:03.790480302 +0200
|
|
|
+@@ -228,13 +228,11 @@
|
|
|
+ */
|
|
|
+ msp_serial_setup();
|
|
|
+
|
|
|
+-#ifdef CONFIG_MIPS_MT_SMP
|
|
|
+- register_smp_ops(&vsmp_smp_ops);
|
|
|
+-#endif
|
|
|
+-
|
|
|
++ if (register_vsmp_smp_ops()) {
|
|
|
+ #ifdef CONFIG_MIPS_MT_SMTC
|
|
|
+- register_smp_ops(&msp_smtc_smp_ops);
|
|
|
++ register_smp_ops(&msp_smtc_smp_ops);
|
|
|
+ #endif
|
|
|
++ }
|
|
|
+
|
|
|
+ #ifdef CONFIG_PMCTWILED
|
|
|
+ /*
|