Skip to content
Snippets Groups Projects
Commit cecf2db2 authored by Akshay Saraswat's avatar Akshay Saraswat Committed by Minkyu Kang
Browse files

Exynos542x: Fix secondary core booting for thumb


When compiled SPL for Thumb secondary cores failed to boot
at the kernel boot up. Only one core came up out of 4.
This was happening because the code relocated to the
address 0x02073000 by the primary core was an ARM asm
code which was executed by the secondary cores as if it
was a thumb code.
This patch fixes the issue of secondary cores considering
relocated code as Thumb instructions and not ARM instructions
by jumping to the relocated with the help of "bx" ARM instruction.
"bx" instruction changes the 5th bit of CPSR which allows
execution unit to consider the following instructions as ARM
instructions.

Signed-off-by: default avatarAkshay Saraswat <akshay.s@samsung.com>
Reviewed-by: default avatarSimon Glass <sjg@chromium.org>
Tested-by: default avatarSimon Glass <sjg@chromium.org>
Signed-off-by: default avatarMinkyu Kang <mk7.kang@samsung.com>
parent 7e514eef
No related branches found
No related tags found
No related merge requests found
...@@ -89,7 +89,7 @@ static void secondary_cpu_start(void) ...@@ -89,7 +89,7 @@ static void secondary_cpu_start(void)
{ {
v7_enable_smp(EXYNOS5420_INFORM_BASE); v7_enable_smp(EXYNOS5420_INFORM_BASE);
svc32_mode_en(); svc32_mode_en();
set_pc(CONFIG_EXYNOS_RELOCATE_CODE_BASE); branch_bx(CONFIG_EXYNOS_RELOCATE_CODE_BASE);
} }
/* /*
......
...@@ -75,6 +75,9 @@ struct exynos5_sysreg { ...@@ -75,6 +75,9 @@ struct exynos5_sysreg {
/* Set program counter with the given value */ /* Set program counter with the given value */
#define set_pc(x) __asm__ __volatile__ ("mov pc, %0\n\t" : : "r"(x)) #define set_pc(x) __asm__ __volatile__ ("mov pc, %0\n\t" : : "r"(x))
/* Branch to the given location */
#define branch_bx(x) __asm__ __volatile__ ("bx %0\n\t" : : "r"(x))
/* Read Main Id register */ /* Read Main Id register */
#define mrc_midr(x) __asm__ __volatile__ \ #define mrc_midr(x) __asm__ __volatile__ \
("mrc p15, 0, %0, c0, c0, 0\n\t" : "=r"(x) : ) ("mrc p15, 0, %0, c0, c0, 0\n\t" : "=r"(x) : )
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment