Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/arch/evbarm/fdt remove ifdef __clang.
details: https://anonhg.NetBSD.org/src/rev/c3b8a4a03586
branches: trunk
changeset: 324771:c3b8a4a03586
user: ryo <ryo%NetBSD.org@localhost>
date: Wed Jul 18 06:50:48 2018 +0000
description:
remove ifdef __clang.
make position independent, and cleanup.
diffstat:
sys/arch/evbarm/fdt/fdt_start.S | 41 ++++++++++++++---------------------------
1 files changed, 14 insertions(+), 27 deletions(-)
diffs (78 lines):
diff -r 31d79f14bdd3 -r c3b8a4a03586 sys/arch/evbarm/fdt/fdt_start.S
--- a/sys/arch/evbarm/fdt/fdt_start.S Wed Jul 18 02:18:45 2018 +0000
+++ b/sys/arch/evbarm/fdt/fdt_start.S Wed Jul 18 06:50:48 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fdt_start.S,v 1.2 2018/07/17 00:37:42 christos Exp $ */
+/* $NetBSD: fdt_start.S,v 1.3 2018/07/18 06:50:48 ryo Exp $ */
/*
* Copyright (c) 2017 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -32,11 +32,17 @@
#include <aarch64/asm.h>
-RCSID("$NetBSD: fdt_start.S,v 1.2 2018/07/17 00:37:42 christos Exp $")
+RCSID("$NetBSD: fdt_start.S,v 1.3 2018/07/18 06:50:48 ryo Exp $")
#define PRINT(string) \
bl xprint;.asciz string;.align 2
+/* 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.
*/
@@ -47,29 +53,16 @@
sub x10, x10, x9
-#ifdef __clang__
- ldr x8, =(kern_vtopdiff - start)
-#else
- ldr x7, =start
- ldr x8, =kern_vtopdiff
- sub x8, x8, x7
-#endif
- add x8, x8, x9
- str x10, [x8]
+ /* 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]
*/
- /* offset of uboot_args from start */
-#ifdef __clang__
- ldr x8, =(uboot_args - start)
-#else
- ldr x8, =uboot_args
- sub x8, x8, x7
-#endif
- add x8, x8, x9 /* add load address to offset */
-
+ /* address of uboot_args (relative) */
+ ADDR x8, uboot_args
str x0, [x8, #(8*0)]
str x1, [x8, #(8*1)]
str x2, [x8, #(8*2)]
@@ -78,13 +71,7 @@
/*
* ARM64 boot protocol has FDT address in x0 *
*/
-#ifdef __clang__
- ldr x8, =(fdt_addr_r - start)
-#else
- ldr x8, =fdt_addr_r
- sub x8, x8, x7
-#endif
- add x8, x8, x9
+ ADDR x8, fdt_addr_r
str x0, [x8]
Home |
Main Index |
Thread Index |
Old Index