diff options
author | jogo <jogo@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2014-01-13 12:13:05 +0000 |
---|---|---|
committer | jogo <jogo@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2014-01-13 12:13:05 +0000 |
commit | bcd764a55058935d0f2c01c37921f2929a0e4be5 (patch) | |
tree | 732ecafa93b6d8c1b75ad0fcbb464ba60dc605d4 /target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch | |
parent | 8843176b6863e5c5dce4b3772cf734ed5f6c2975 (diff) |
brcm63xx: update bmips patches with upstream submission
Update bmips cleanup patches with upstream submission and backport a few
bmips fixes.
Signed-off-by: Jonas Gorski <jogo@openwrt.org>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@39267 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch')
-rw-r--r-- | target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch b/target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch new file mode 100644 index 0000000000..58658290c3 --- /dev/null +++ b/target/linux/brcm63xx/patches-3.10/056-MIPS-BMIPS-Fix-thinko-to-release-slave-TP-from-reset.patch @@ -0,0 +1,37 @@ +From 976f39b139cdd06a88a5aadd8202b0c30cac9cda Mon Sep 17 00:00:00 2001 +From: Florian Fainelli <florian@openwrt.org> +Date: Wed, 17 Jul 2013 17:56:31 +0000 +Subject: [PATCH] MIPS: BMIPS: Fix thinko to release slave TP from reset + +Commit 4df715aa ["MIPS: BMIPS: support booting from physical CPU other +than 0"] introduced a thinko which will prevents slave CPUs from being +released from reset on systems where we boot from TP0. The problem is +that we are checking whether the slave CPU logical CPU map is 0, which +is never true for systems booting from TP0, so we do not release the +slave TP from reset and we are just stuck. Fix this by properly checking +that the CPU we intend to boot really is the physical slave CPU (logical +and physical value being 1). + +Signed-off-by: Florian Fainelli <florian@openwrt.org> +Cc: linux-mips@linux-mips.org +Cc: blogic@openwrt.org +Cc: jogo@openwrt.org +Cc: cernekee@gmail.com +Cc: Florian Fainelli <florian@openwrt.org> +Patchwork: https://patchwork.linux-mips.org/patch/5598/ +Signed-off-by: Ralf Baechle <ralf@linux-mips.org> +--- + arch/mips/kernel/smp-bmips.c | 2 +- + 1 file changed, 1 insertion(+), 1 deletion(-) + +--- a/arch/mips/kernel/smp-bmips.c ++++ b/arch/mips/kernel/smp-bmips.c +@@ -173,7 +173,7 @@ static void bmips_boot_secondary(int cpu + else { + #if defined(CONFIG_CPU_BMIPS4350) || defined(CONFIG_CPU_BMIPS4380) + /* Reset slave TP1 if booting from TP0 */ +- if (cpu_logical_map(cpu) == 0) ++ if (cpu_logical_map(cpu) == 1) + set_c0_brcm_cmt_ctrl(0x01); + #elif defined(CONFIG_CPU_BMIPS5000) + if (cpu & 0x01) |