blob: f0e1c805b01f71c48a935a3932e85545337c3d46 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09002/*
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +02003 * Copyright (C) 2016 Vladimir Zapolskiy <vz@mleia.com>
4 * Copyright (C) 2007, 2010 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09005 */
6
Wolfgang Denk0191e472010-10-26 14:34:52 +02007#include <asm-offsets.h>
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09008#include <config.h>
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +09009
10 .text
11 .align 2
12
13 .global _start
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020014_start:
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090015 mov.l ._lowlevel_init, r0
16100: bsrf r0
17 nop
18
19 bsr 1f
20 nop
211: sts pr, r5
Wolfgang Denk0a5c2142007-12-27 01:52:50 +010022 mov.l ._reloc_dst, r4
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020023 add #(_start-1b), r5
Wolfgang Denk0a5c2142007-12-27 01:52:50 +010024 mov.l ._reloc_dst_end, r6
Marek Vasut5d0cd632019-09-01 18:05:03 +020025#ifdef CONFIG_OF_SEPARATE
26 mov.l ._reloc_size, r0
27 add r5, r0
28 add #4, r0
29 mov.l @r0, r0
30 swap.b r0, r0
31 swap.w r0, r0
32 swap.b r0, r0
33 add #4, r0
34 add r0, r6
35#endif
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090036
372: mov.l @r5+, r1
38 mov.l r1, @r4
39 add #4, r4
40 cmp/hs r6, r4
41 bf 2b
Wolfgang Denk0a5c2142007-12-27 01:52:50 +010042
Marek Vasut5d0cd632019-09-01 18:05:03 +020043#ifndef CONFIG_OF_SEPARATE
Wolfgang Denk0a5c2142007-12-27 01:52:50 +010044 mov.l ._bss_start, r4
45 mov.l ._bss_end, r5
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090046 mov #0, r1
47
Wolfgang Denk0a5c2142007-12-27 01:52:50 +0100483: mov.l r1, @r4 /* bss clear */
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090049 add #4, r4
50 cmp/hs r5, r4
51 bf 3b
Marek Vasut5d0cd632019-09-01 18:05:03 +020052#endif
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090053
54 mov.l ._gd_init, r13 /* global data */
55 mov.l ._stack_init, r15 /* stack */
Simon Glassadad2d02023-09-26 08:14:27 -060056#if CONFIG_IS_ENABLED(SYS_MALLOC_F)
Marek Vasut9a9247c2020-05-09 22:02:50 +020057 mov.l ._gd_malloc_base, r14
58 mov.l r15, @r14
59#endif
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020060 mov.l ._sh_generic_init, r0
61 jsr @r0
62 mov #0, r4
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090063
64loop:
65 bra loop
66
67 .align 2
68
69._lowlevel_init: .long (lowlevel_init - (100b + 4))
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020070._reloc_dst: .long _start
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090071._reloc_dst_end: .long reloc_dst_end
Marek Vasut5d0cd632019-09-01 18:05:03 +020072._reloc_size: .long (_end - _start)
Nobuhiro Iwamatsu970dc332007-05-13 20:58:00 +090073._bss_start: .long bss_start
74._bss_end: .long bss_end
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020075._gd_init: .long (_start - GENERATED_GBL_DATA_SIZE)
Simon Glassadad2d02023-09-26 08:14:27 -060076#if CONFIG_IS_ENABLED(SYS_MALLOC_F)
Marek Vasut9a9247c2020-05-09 22:02:50 +020077._gd_malloc_base: .long (_start - GENERATED_GBL_DATA_SIZE + GD_MALLOC_BASE)
78#endif
Vladimir Zapolskiy946c8c82016-11-28 00:15:33 +020079._stack_init: .long (_start - GENERATED_GBL_DATA_SIZE - CONFIG_SYS_MALLOC_LEN - 16)
80._sh_generic_init: .long board_init_f