diff options
-rw-r--r-- | target/linux/malta/Makefile | 2 | ||||
-rw-r--r-- | target/linux/malta/le/config-default | 7 | ||||
-rw-r--r-- | target/linux/malta/patches-3.0/001-mips-malta-fix-crash-smp-kernel-on-non-cmp-systems.patch | 166 |
3 files changed, 171 insertions, 4 deletions
diff --git a/target/linux/malta/Makefile b/target/linux/malta/Makefile index dcddd2cad..4fbdf49d1 100644 --- a/target/linux/malta/Makefile +++ b/target/linux/malta/Makefile @@ -13,7 +13,7 @@ SUBTARGETS:=le be INITRAMFS_EXTRA_FILES:= MAINTAINER:=Florian Fainelli <florian@openwrt.org> -LINUX_VERSION:=2.6.39.2 +LINUX_VERSION:=3.0 include $(INCLUDE_DIR)/target.mk diff --git a/target/linux/malta/le/config-default b/target/linux/malta/le/config-default index 4538de789..c0dc06368 100644 --- a/target/linux/malta/le/config-default +++ b/target/linux/malta/le/config-default @@ -10,6 +10,7 @@ CONFIG_ARCH_SUPPORTS_OPROFILE=y # CONFIG_ATH79 is not set CONFIG_AX88796=m # CONFIG_AX88796_93CX6 is not set +CONFIG_BCMA_POSSIBLE=y # CONFIG_BE2NET is not set # CONFIG_BLK_DEV_DM is not set # CONFIG_BLK_DEV_INITRD is not set @@ -28,6 +29,7 @@ CONFIG_CC_OPTIMIZE_FOR_SIZE=y CONFIG_CEVT_R4K=y CONFIG_CEVT_R4K_LIB=y CONFIG_CICADA_PHY=m +CONFIG_CLKSRC_I8253=y # CONFIG_CLS_U32_MARK is not set # CONFIG_CLS_U32_PERF is not set CONFIG_CONSOLE_TRANSLATIONS=y @@ -86,8 +88,6 @@ CONFIG_GENERIC_ATOMIC64=y CONFIG_GENERIC_CLOCKEVENTS=y CONFIG_GENERIC_CLOCKEVENTS_BUILD=y CONFIG_GENERIC_CMOS_UPDATE=y -CONFIG_GENERIC_FIND_LAST_BIT=y -CONFIG_GENERIC_FIND_NEXT_BIT=y CONFIG_GENERIC_IRQ_SHOW=y CONFIG_GENERIC_ISA_DMA=y # CONFIG_HAMRADIO is not set @@ -128,7 +128,6 @@ CONFIG_ICPLUS_PHY=m CONFIG_IMAGE_CMDLINE_HACK=y CONFIG_INET_DIAG=y CONFIG_INET_TCP_DIAG=y -CONFIG_INOTIFY_USER=y CONFIG_INPUT=y # CONFIG_INPUT_MISC is not set CONFIG_INPUT_MOUSEDEV=y @@ -147,6 +146,8 @@ CONFIG_JFFS2_FS_POSIX_ACL=y CONFIG_JFFS2_FS_SECURITY=y # CONFIG_JFFS2_SUMMARY is not set CONFIG_KALLSYMS=y +CONFIG_KERNEL_GZIP=y +# CONFIG_LANTIQ is not set # CONFIG_LEDS_TRIGGER_TIMER is not set CONFIG_LEGACY_PTYS=y CONFIG_LEGACY_PTY_COUNT=256 diff --git a/target/linux/malta/patches-3.0/001-mips-malta-fix-crash-smp-kernel-on-non-cmp-systems.patch b/target/linux/malta/patches-3.0/001-mips-malta-fix-crash-smp-kernel-on-non-cmp-systems.patch new file mode 100644 index 000000000..03866df7f --- /dev/null +++ b/target/linux/malta/patches-3.0/001-mips-malta-fix-crash-smp-kernel-on-non-cmp-systems.patch @@ -0,0 +1,166 @@ +From d9a056919c4fa46cd9e094f969032bd4e15bffef Mon Sep 17 00:00:00 2001 +From: Ralf Baechle <ralf@linux-mips.org> +Date: Sat, 28 May 2011 15:27:59 +0100 +Subject: [PATCH] MIPS: Malta: Fix crash SMP kernel on non-CMP systems. + +Since 6be63bbbdab66b9185dc6f67c8b1bacb6f37f946 (lmo) rsp. +af3a1f6f4813907e143f87030cde67a9971db533 (kernel.org) the Malta code does +no longer probe for presence of GCMP if CMP is not configured. This means +that the variable gcmp_present well be left at its default value of -1 +which normally is meant to indicate that GCMP has not yet been mmapped. +This non-zero value is now interpreted as GCMP being present resulting +in a write attempt to a GCMP register resulting in a crash. + +Reported and a build fix on top of my fix by Rob Landley <rob@landley.net>. + +Reported-by: Rob Landley <rob@landley.net> +Signed-off-by: Ralf Baechle <ralf@linux-mips.org> +Patchwork: https://patchwork.linux-mips.org/patch/2413/ +(cherry picked from commit c3ddf592134eaab38d051b2e7b23e81201ae423a) +--- + arch/mips/include/asm/smp-ops.h | 41 +++++++++++++++++++++++++++-- + arch/mips/mipssim/sim_setup.c | 17 ++++++------ + arch/mips/mti-malta/malta-init.c | 14 +++++----- + arch/mips/pmc-sierra/msp71xx/msp_setup.c | 8 ++--- + 4 files changed, 56 insertions(+), 24 deletions(-) + +diff --git a/arch/mips/include/asm/smp-ops.h b/arch/mips/include/asm/smp-ops.h +index 9e09af3..48b03ff 100644 +--- a/arch/mips/include/asm/smp-ops.h ++++ b/arch/mips/include/asm/smp-ops.h +@@ -56,8 +56,43 @@ static inline void register_smp_ops(struct plat_smp_ops *ops) + + #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 --git a/arch/mips/mipssim/sim_setup.c b/arch/mips/mipssim/sim_setup.c +index 55f22a3..1970069 100644 +--- a/arch/mips/mipssim/sim_setup.c ++++ b/arch/mips/mipssim/sim_setup.c +@@ -59,18 +59,17 @@ void __init prom_init(void) + + 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 --git a/arch/mips/mti-malta/malta-init.c b/arch/mips/mti-malta/malta-init.c +index 31180c3..4b988b9 100644 +--- a/arch/mips/mti-malta/malta-init.c ++++ b/arch/mips/mti-malta/malta-init.c +@@ -28,6 +28,7 @@ + #include <asm/io.h> + #include <asm/system.h> + #include <asm/cacheflush.h> ++#include <asm/smp-ops.h> + #include <asm/traps.h> + + #include <asm/gcmpregs.h> +@@ -358,15 +359,14 @@ void __init prom_init(void) + #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 --git a/arch/mips/pmc-sierra/msp71xx/msp_setup.c b/arch/mips/pmc-sierra/msp71xx/msp_setup.c +index 2413ea6..0abfbe0 100644 +--- a/arch/mips/pmc-sierra/msp71xx/msp_setup.c ++++ b/arch/mips/pmc-sierra/msp71xx/msp_setup.c +@@ -228,13 +228,11 @@ void __init prom_init(void) + */ + 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 + /* +-- +1.7.3.4 + |