Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/arm/altera make CPU 1 bootstrapping work even if th...
details: https://anonhg.NetBSD.org/src/rev/c2e3bab484c7
branches: trunk
changeset: 999126:c2e3bab484c7
user: aymeric <aymeric%NetBSD.org@localhost>
date: Mon May 20 20:17:25 2019 +0000
description:
make CPU 1 bootstrapping work even if the kernel is not loaded close to PA 0.
More precisely, we used "B cpu_mpstart", which worked for small addresses and
thus does not work in the EFI case.
It is now replaced by a "LDR PC, =cpu_mpstart", which works for arbitrary
addresses.
diffstat:
sys/arch/arm/altera/cycv_platform.c | 19 +++++++++++--------
1 files changed, 11 insertions(+), 8 deletions(-)
diffs (46 lines):
diff -r 789619839ea3 -r c2e3bab484c7 sys/arch/arm/altera/cycv_platform.c
--- a/sys/arch/arm/altera/cycv_platform.c Mon May 20 20:14:08 2019 +0000
+++ b/sys/arch/arm/altera/cycv_platform.c Mon May 20 20:17:25 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cycv_platform.c,v 1.10 2019/01/31 13:06:10 skrll Exp $ */
+/* $NetBSD: cycv_platform.c,v 1.11 2019/05/20 20:17:25 aymeric Exp $ */
/* This file is in the public domain. */
@@ -7,7 +7,7 @@
#include "opt_multiprocessor.h"
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cycv_platform.c,v 1.10 2019/01/31 13:06:10 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cycv_platform.c,v 1.11 2019/05/20 20:17:25 aymeric Exp $");
#define _ARM32_BUS_DMA_PRIVATE
#include <sys/param.h>
@@ -92,18 +92,21 @@
bus_space_write_4(bst, bsh_scu, SCU_CTL,
bus_space_read_4(bst, bsh_scu, SCU_CTL) | SCU_CTL_SCU_ENA);
- const uint32_t startfunc = (uint32_t) KERN_VTOPHYS((vaddr_t)cpu_mpstart);
+ const uint32_t startfunc =
+ (uint32_t) KERN_VTOPHYS((vaddr_t) cpu_mpstart);
/*
- * We place a "B cortex_mpstart" at address 0 in order to bootstrap
+ * We place a "LDR PC, =cpu_mpstart" at address 0 in order to bootstrap
* CPU 1. We can't use the similar feature of the Boot ROM because
- * it was unmapped by u-boot in favor of the SDRAM. Plus the dtb is
- * stored very low in RAM so we can't re-map the Boot ROM easily.
+ * it was unmapped by u-boot in favor of the SDRAM.
*/
pmap_map_chunk(kernel_l1pt.pv_va, CYCV_SDRAM_VBASE, CYCV_SDRAM_BASE,
L1_S_SIZE, VM_PROT_READ|VM_PROT_WRITE, PMAP_NOCACHE);
- *(volatile uint32_t *) CYCV_SDRAM_VBASE =
- htole32(0xea000000 | ((startfunc - 8 - 0x0) >> 2));
+
+ /* 0: LDR PC, [PC, #0x18] -> loads address at 0x20 into PC */
+ *(volatile uint32_t *) CYCV_SDRAM_VBASE = htole32(0xe59ff018);
+ *(volatile uint32_t *) (CYCV_SDRAM_VBASE + 0x20) = startfunc;
+
pmap_unmap_chunk(kernel_l1pt.pv_va, CYCV_SDRAM_VBASE, L1_S_SIZE);
bus_space_write_4(bst, bsh_rst, CYCV_RSTMGR_MPUMODRST,
Home |
Main Index |
Thread Index |
Old Index