Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbarm Start code now updates a global variable fdt...
details: https://anonhg.NetBSD.org/src/rev/6c5a1cd33c98
branches: trunk
changeset: 359968:6c5a1cd33c98
user: skrll <skrll%NetBSD.org@localhost>
date: Sat Mar 03 13:46:32 2018 +0000
description:
Start code now updates a global variable fdt_addr_r to handle differences
in boot protocol (think arm64)
diffstat:
sys/arch/evbarm/exynos/exynos_start.S | 17 +++++++++++++----
sys/arch/evbarm/fdt/fdt_machdep.c | 11 +++++++----
sys/arch/evbarm/rpi/rpi2_start.S | 13 ++++++++++++-
sys/arch/evbarm/rpi/rpi_start.S | 11 +++++++++--
sys/arch/evbarm/sunxi/sunxi_start.S | 15 +++++++++++++--
sys/arch/evbarm/tegra/tegra_start.S | 15 +++++++++++++--
sys/arch/evbarm/ti/ti_start.S | 15 +++++++++++++--
sys/arch/evbarm/vexpress/vexpress_start.S | 15 +++++++++++++--
8 files changed, 93 insertions(+), 19 deletions(-)
diffs (truncated from 336 to 300 lines):
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/exynos/exynos_start.S
--- a/sys/arch/evbarm/exynos/exynos_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/exynos/exynos_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: exynos_start.S,v 1.4 2017/06/10 23:20:56 jmcneill Exp $ */
+/* $NetBSD: exynos_start.S,v 1.5 2018/03/03 13:46:32 skrll Exp $ */
/*-
* Copyright (c) 2014 The NetBSD Foundation, Inc.
@@ -35,6 +35,7 @@
#include "opt_cputypes.h"
#include "opt_multiprocessor.h"
#include "opt_arm_debug.h"
+#include "opt_fdt.h"
#include <arm/asm.h>
#include <arm/armreg.h>
@@ -45,7 +46,7 @@
#include <evbarm/exynos/platform.h>
-RCSID("$NetBSD: exynos_start.S,v 1.4 2017/06/10 23:20:56 jmcneill Exp $")
+RCSID("$NetBSD: exynos_start.S,v 1.5 2018/03/03 13:46:32 skrll Exp $")
#if defined(VERBOSE_INIT_ARM)
@@ -95,10 +96,18 @@
*/
movw r4, #:lower16:uboot_args
movt r4, #:upper16:uboot_args
-#if KERNEL_BASE_VOFFSET != 0
sub r4, r4, #KERNEL_BASE_VOFFSET
+ stmia r4, {r0-r3} // Save the arguments
+
+#ifdef FDT
+ /*
+ * ARM boot protocol has FDT address in r2
+ */
+ movw r4, #:lower16:fdt_addr_r
+ movt r4, #:upper16:fdt_addr_r
+ sub r4, r4, #KERNEL_BASE_VOFFSET
+ str r2, [r4]
#endif
- stmia r4, {r0-r3} // Save the arguments
/* Add DTB PA (1MB) from r2 to MMU init table */
movw r3, #:lower16:(L1_S_SIZE - 1) /* align DTB PA to 1M */
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/fdt/fdt_machdep.c
--- a/sys/arch/evbarm/fdt/fdt_machdep.c Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/fdt/fdt_machdep.c Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fdt_machdep.c,v 1.19 2017/12/21 08:28:55 skrll Exp $ */
+/* $NetBSD: fdt_machdep.c,v 1.20 2018/03/03 13:46:32 skrll Exp $ */
/*-
* Copyright (c) 2015-2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: fdt_machdep.c,v 1.19 2017/12/21 08:28:55 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fdt_machdep.c,v 1.20 2018/03/03 13:46:32 skrll Exp $");
#include "opt_machdep.h"
#include "opt_ddb.h"
@@ -87,7 +87,11 @@
BootConfig bootconfig;
char bootargs[FDT_MAX_BOOT_STRING] = "";
char *boot_args = NULL;
-u_int uboot_args[4] = { 0 }; /* filled in by xxx_start.S (not in bss) */
+/*
+ * filled in by xxx_start.S (must not be in bss)
+ */
+unsigned long uboot_args[4] = { 0 };
+const uint8_t *fdt_addr_r = (const uint8_t *)0xdeadc0de;
static char fdt_memory_ext_storage[EXTENT_FIXED_STORAGE_SIZE(DRAM_BLOCKS)];
static struct extent *fdt_memory_ext;
@@ -333,7 +337,6 @@
uint64_t memory_addr, memory_size;
/* Load FDT */
- const uint8_t *fdt_addr_r = (const uint8_t *)uboot_args[2];
int error = fdt_check_header(fdt_addr_r);
if (error == 0) {
error = fdt_move(fdt_addr_r, fdt_data, sizeof(fdt_data));
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/rpi/rpi2_start.S
--- a/sys/arch/evbarm/rpi/rpi2_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/rpi/rpi2_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -32,13 +32,14 @@
#include "opt_cputypes.h"
#include "opt_multiprocessor.h"
#include "opt_arm_debug.h"
+#include "opt_fdt.h"
#include <arm/asm.h>
#include <arm/armreg.h>
#include "assym.h"
-RCSID("$NetBSD: rpi2_start.S,v 1.4 2017/12/10 21:38:27 skrll Exp $")
+RCSID("$NetBSD: rpi2_start.S,v 1.5 2018/03/03 13:46:32 skrll Exp $")
#if defined(KERNEL_BASES_EQUAL)
#define CALL(f) bl _C_LABEL(f)
@@ -100,6 +101,16 @@
stmia r4, {r0-r3} // Save the arguments
+#ifdef FDT
+ /*
+ * ARM boot protocol has FDT address in r2
+ */
+ movw r4, #:lower16:fdt_addr_r
+ movt r4, #:upper16:fdt_addr_r
+ sub r4, r4, #KERNEL_BASE_VOFFSET
+ str r2, [r4]
+#endif
+
/*
* Setup the CPU
*/
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/rpi/rpi_start.S
--- a/sys/arch/evbarm/rpi/rpi_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/rpi/rpi_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rpi_start.S,v 1.16 2018/01/01 11:28:33 skrll Exp $ */
+/* $NetBSD: rpi_start.S,v 1.17 2018/03/03 13:46:32 skrll Exp $ */
/*
* Copyright (c) 2002, 2003 Genetec Corporation. All rights reserved.
@@ -90,12 +90,13 @@
#include "opt_arm_debug.h"
#include "opt_cputypes.h"
#include "opt_cpuoptions.h"
+#include "opt_fdt.h"
#include <machine/asm.h>
#include <arm/armreg.h>
#include "assym.h"
-RCSID("$NetBSD: rpi_start.S,v 1.16 2018/01/01 11:28:33 skrll Exp $")
+RCSID("$NetBSD: rpi_start.S,v 1.17 2018/03/03 13:46:32 skrll Exp $")
#if defined(VERBOSE_INIT_ARM)
@@ -139,6 +140,10 @@
ldr r8, Luboot_args
stmia r8!, {r0-r3}
+#ifdef FDT
+ ldr r8, Lfdt_addr_r
+ str r2, [r8]
+#endif
mrs r0, cpsr
bic r0, r0, #PSR_MODE
orr r0, r0, #(I32_bit | F32_bit | PSR_SVC32_MODE)
@@ -296,6 +301,8 @@
Luboot_args:
.word uboot_args
+Lfdt_addr_r:
+ .word fdt_addr_r
/*
* Coprocessor register initialization values
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/sunxi/sunxi_start.S
--- a/sys/arch/evbarm/sunxi/sunxi_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/sunxi/sunxi_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: sunxi_start.S,v 1.2 2017/11/08 19:49:26 skrll Exp $ */
+/* $NetBSD: sunxi_start.S,v 1.3 2018/03/03 13:46:32 skrll Exp $ */
/*-
* Copyright (c) 2014, 2015 The NetBSD Foundation, Inc.
@@ -35,12 +35,13 @@
#include "opt_multiprocessor.h"
#include "opt_arm_debug.h"
#include "opt_fdt_arm.h"
+#include "opt_fdt.h"
#include <arm/asm.h>
#include <arm/armreg.h>
#include "assym.h"
-RCSID("$NetBSD: sunxi_start.S,v 1.2 2017/11/08 19:49:26 skrll Exp $")
+RCSID("$NetBSD: sunxi_start.S,v 1.3 2018/03/03 13:46:32 skrll Exp $")
#if defined(VERBOSE_INIT_ARM) && defined(CONSADDR)
#define XPUTC(n) mov r0, n; bl xputc
@@ -94,6 +95,16 @@
stmia r4, {r0-r3} // Save the arguments
+#ifdef FDT
+ /*
+ * ARM boot protocol has FDT address in r2
+ */
+ movw r4, #:lower16:fdt_addr_r
+ movt r4, #:upper16:fdt_addr_r
+ sub r4, r4, #KERNEL_BASE_VOFFSET
+ str r2, [r4]
+#endif
+
/* Add DTB PA (1MB) from r2 to MMU init table */
movw r3, #:lower16:(L1_S_SIZE - 1) /* align DTB PA to 1M */
movt r3, #:upper16:(L1_S_SIZE - 1)
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/tegra/tegra_start.S
--- a/sys/arch/evbarm/tegra/tegra_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/tegra/tegra_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tegra_start.S,v 1.15 2017/05/30 22:55:27 jmcneill Exp $ */
+/* $NetBSD: tegra_start.S,v 1.16 2018/03/03 13:46:33 skrll Exp $ */
/*-
* Copyright (c) 2014, 2015 The NetBSD Foundation, Inc.
@@ -35,6 +35,7 @@
#include "opt_multiprocessor.h"
#include "opt_arm_debug.h"
#include "opt_fdt_arm.h"
+#include "opt_fdt.h"
#include <arm/asm.h>
#include <arm/armreg.h>
@@ -42,7 +43,7 @@
#include <arm/nvidia/tegra_reg.h>
-RCSID("$NetBSD: tegra_start.S,v 1.15 2017/05/30 22:55:27 jmcneill Exp $")
+RCSID("$NetBSD: tegra_start.S,v 1.16 2018/03/03 13:46:33 skrll Exp $")
#if defined(VERBOSE_INIT_ARM) && defined(CONSADDR)
#define XPUTC(n) mov r0, n; bl xputc
@@ -96,6 +97,16 @@
stmia r4, {r0-r3} // Save the arguments
+#ifdef FDT
+ /*
+ * ARM boot protocol has FDT address in r2
+ */
+ movw r4, #:lower16:fdt_addr_r
+ movt r4, #:upper16:fdt_addr_r
+ sub r4, r4, #KERNEL_BASE_VOFFSET
+ str r2, [r4]
+#endif
+
/*
* Turn on the SMP bit
*/
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/ti/ti_start.S
--- a/sys/arch/evbarm/ti/ti_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/ti/ti_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ti_start.S,v 1.1 2017/10/26 01:16:32 jakllsch Exp $ */
+/* $NetBSD: ti_start.S,v 1.2 2018/03/03 13:46:33 skrll Exp $ */
/*-
* Copyright (c) 2014, 2015 The NetBSD Foundation, Inc.
@@ -34,6 +34,7 @@
#include "opt_multiprocessor.h"
#include "opt_arm_debug.h"
#include "opt_fdt_arm.h"
+#include "opt_fdt.h"
#include <arm/asm.h>
#include <arm/armreg.h>
@@ -41,7 +42,7 @@
#include <arch/arm/ti/ti_platform.h>
-RCSID("$NetBSD: ti_start.S,v 1.1 2017/10/26 01:16:32 jakllsch Exp $")
+RCSID("$NetBSD: ti_start.S,v 1.2 2018/03/03 13:46:33 skrll Exp $")
#if defined(VERBOSE_INIT_ARM) && defined(CONSADDR)
#define XPUTC(n) mov r0, n; bl xputc
@@ -95,6 +96,16 @@
stmia r4, {r0-r3} // Save the arguments
+#ifdef FDT
+ /*
+ * ARM boot protocol has FDT address in r2
+ */
+ movw r4, #:lower16:fdt_addr_r
+ movt r4, #:upper16:fdt_addr_r
+ sub r4, r4, #KERNEL_BASE_VOFFSET
+ str r2, [r4]
+#endif
+
/* Add DTB PA (1MB) from r2 to MMU init table */
movw r3, #:lower16:(L1_S_SIZE - 1) /* align DTB PA to 1M */
movt r3, #:upper16:(L1_S_SIZE - 1)
diff -r dc07059dac08 -r 6c5a1cd33c98 sys/arch/evbarm/vexpress/vexpress_start.S
--- a/sys/arch/evbarm/vexpress/vexpress_start.S Sat Mar 03 11:23:24 2018 +0000
+++ b/sys/arch/evbarm/vexpress/vexpress_start.S Sat Mar 03 13:46:32 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vexpress_start.S,v 1.5 2017/06/04 19:15:46 jmcneill Exp $ */
+/* $NetBSD: vexpress_start.S,v 1.6 2018/03/03 13:46:33 skrll Exp $ */
Home |
Main Index |
Thread Index |
Old Index