summaryrefslogtreecommitdiff
path: root/arch/arm/lib
diff options
context:
space:
mode:
authortnishinaga.dev@gmail.com <tnishinaga.dev@gmail.com>2017-06-04 16:18:08 (GMT)
committerTom Rini <trini@konsulko.com>2017-06-10 00:34:54 (GMT)
commit8f079cccb369995e46a2ab530d5d60b88c1e70bb (patch)
tree56a52663270313cb0fdd5b3e1bd2e304d628c892 /arch/arm/lib
parent00bbe96ebabbc83777cd8d6c6fd2791c5c8cf619 (diff)
downloadu-boot-8f079cccb369995e46a2ab530d5d60b88c1e70bb.tar.xz
armv7m: Disable D-cache when booting nommu(ARMv7M) Linux kernel
Disable D-Cache is required when booting nommu Linux kernel. (please see Linux kernel source "arch/arm/kernel/head-nommu.S") U-Boot is enabled D-cache and I-Cache at startup. However, it does not disable D-Cache before booting nommu Linux kernel. Therefore, I call dcache_disable() when the CPU is ARMv7M to fix this problem. Signed-off-by: Toshifumi NISHINAGA <tnishinaga.dev@gmail.com>
Diffstat (limited to 'arch/arm/lib')
-rw-r--r--arch/arm/lib/bootm.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/arch/arm/lib/bootm.c b/arch/arm/lib/bootm.c
index 704849b..b3e5d24 100644
--- a/arch/arm/lib/bootm.c
+++ b/arch/arm/lib/bootm.c
@@ -360,6 +360,7 @@ static void boot_jump_linux(bootm_headers_t *images, int flag)
#ifdef CONFIG_CPU_V7M
ulong addr = (ulong)kernel_entry | 1;
kernel_entry = (void *)addr;
+ dcache_disable();
#endif
s = getenv("machid");
if (s) {