Module Name:    src
Committed By:   skrll
Date:           Fri Sep 14 09:06:13 UTC 2018

Modified Files:
        src/sys/arch/evbarm/conf: mk.generic64
Added Files:
        src/sys/arch/aarch64/aarch64: start.S
Removed Files:
        src/sys/arch/evbarm/fdt: fdt_start.S genassym.cf

Log Message:
Move the aarch64 start stub from sys/arch/evbarm to sys/arch/aarch64.

Delete the unused/empty evbarm/fdt/genassym.cf while I'm here.


To generate a diff of this commit:
cvs rdiff -u -r0 -r1.1 src/sys/arch/aarch64/aarch64/start.S
cvs rdiff -u -r1.1 -r1.2 src/sys/arch/evbarm/conf/mk.generic64
cvs rdiff -u -r1.4 -r0 src/sys/arch/evbarm/fdt/fdt_start.S
cvs rdiff -u -r1.1 -r0 src/sys/arch/evbarm/fdt/genassym.cf

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/arch/evbarm/conf/mk.generic64
diff -u src/sys/arch/evbarm/conf/mk.generic64:1.1 src/sys/arch/evbarm/conf/mk.generic64:1.2
--- src/sys/arch/evbarm/conf/mk.generic64:1.1	Sun Apr  1 04:35:04 2018
+++ src/sys/arch/evbarm/conf/mk.generic64	Fri Sep 14 09:06:12 2018
@@ -1,7 +1,7 @@
-#	$NetBSD: mk.generic64,v 1.1 2018/04/01 04:35:04 ryo Exp $
+#	$NetBSD: mk.generic64,v 1.2 2018/09/14 09:06:12 skrll Exp $
 
-SYSTEM_FIRST_OBJ=	fdt_start.o
-SYSTEM_FIRST_SFILE=	${THISARM}/fdt/fdt_start.S
+SYSTEM_FIRST_OBJ=	start.o
+SYSTEM_FIRST_SFILE=	${ARM}/aarch64/start.S
 
 _OSRELEASE!=		${HOST_SH} $S/conf/osrelease.sh
 
@@ -10,8 +10,6 @@ BOARDTYPE=		evbarm64
 MKUBOOTIMAGEARGS=	-f arm64
 MKKNLIMG=		${THISARM}/compile/rpi-mkknlimg.sh
 
-GENASSYM_EXTRAS+=	${THISARM}/fdt/genassym.cf
-
 SYSTEM_LD_TAIL_EXTRA+=; \
 	echo ${OBJCOPY} -S -O binary $@ [email protected]; \
 	${OBJCOPY} -S -O binary $@ [email protected]; \

Added files:

Index: src/sys/arch/aarch64/aarch64/start.S
diff -u /dev/null src/sys/arch/aarch64/aarch64/start.S:1.1
--- /dev/null	Fri Sep 14 09:06:13 2018
+++ src/sys/arch/aarch64/aarch64/start.S	Fri Sep 14 09:06:12 2018
@@ -0,0 +1,80 @@
+/*	$NetBSD: start.S,v 1.1 2018/09/14 09:06:12 skrll Exp $	*/
+
+/*
+ * Copyright (c) 2017 Ryo Shimizu <[email protected]>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
+ * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
+ * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
+ * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "opt_arm_debug.h"	/* VERBOSE_INIT_ARM */
+
+#include <sys/cdefs.h>
+
+#include <aarch64/asm.h>
+
+RCSID("$NetBSD: start.S,v 1.1 2018/09/14 09:06:12 skrll Exp $")
+
+/* load far effective address (pc relative) */
+.macro	ADDR, reg, addr
+	adrp	\reg, \addr
+	add	\reg, \reg, #:lo12:\addr
+.endm
+
+/*
+ * Kernel start routine for aarch64 boards.
+ */
+	.global start
+start:
+	adr	x9, start
+	ldr	x10, =start
+
+	sub	x10, x10, x9
+
+	/* address of kern_vtopdiff (relative) */
+	ADDR	x8, kern_vtopdiff
+	str	x10, [x8]	/* kern_vtopdiff = start(virt) - start(phys) */
+
+	/*
+	 * store uboot arguments to uboot_args[4]
+	 */
+
+	/* address of uboot_args (relative) */
+	ADDR	x8, uboot_args
+	str	x0, [x8, #(8*0)]
+	str	x1, [x8, #(8*1)]
+	str	x2, [x8, #(8*2)]
+	str	x3, [x8, #(8*3)]
+
+	/*
+	 * ARM64 boot protocol has FDT address in x0 *
+	 */
+	ADDR	x8, fdt_addr_r
+	str	x0, [x8]
+
+	b	aarch64_start		/* aarch64_start() @ aarch64/locore.S */
+
+ENTRY_NP(uartputc)
+#ifdef EARLYCONS
+	b	___CONCAT(EARLYCONS, _platform_early_putchar)
+#endif
+	ret

Reply via email to