blob: 6171edcce294b0f85352dd1463bcb0a91fb974e3 [file] [log] [blame]
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +09001/*
2 * Copyright (C) 2007,2008 Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
3 * Copyright (C) 2008 Renesas Solutions Corp.
4
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +09006 */
7
Wolfgang Denk0191e472010-10-26 14:34:52 +02008#include <asm-offsets.h>
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +09009#include <config.h>
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +090010
11 .text
12 .align 2
13
14 .global _start
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090015_sh_start:
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +090016 .long 0x00000010 /* Ppower ON reset PC*/
17 .long 0x00000000
18 .long 0x00000010 /* Manual reset PC */
19 .long 0x00000000
20_init:
21 mov.l ._lowlevel_init, r0
22100: bsrf r0
23 nop
24 bsr 1f
25 nop
261: sts pr, r5
27 mov.l ._reloc_dst, r4
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090028 add #(_sh_start-1b), r5
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +090029 mov.l ._reloc_dst_end, r6
30
312: mov.l @r5+, r1
32 mov.l r1, @r4
33 add #4, r4
34 cmp/hs r6, r4
35 bf 2b
36
37 mov.l ._bss_start, r4
38 mov.l ._bss_end, r5
39 mov #0, r1
40
413: mov.l r1, @r4 /* bss clear */
42 add #4, r4
43 cmp/hs r5, r4
44 bf 3b
45
46 mov.l ._gd_init, r13 /* global data */
47 mov.l ._stack_init, r15 /* stack */
48
Simon Glass6c2afb82016-05-14 18:49:29 -060049 #TODO(sh maintainer): Fix this up to call the correct code
50 #mov.l ._sh_generic_init, r0
51 #jsr @r0
Nobuhiro Iwamatsu5b6918e2008-08-31 22:48:33 +090052 nop
53
54loop:
55 bra loop
56
57 .align 2
58
59._lowlevel_init: .long (lowlevel_init - (100b + 4))
60._reloc_dst: .long reloc_dst
61._reloc_dst_end: .long reloc_dst_end
62._bss_start: .long bss_start
63._bss_end: .long bss_end
Nobuhiro Iwamatsua0dbe932010-11-24 13:12:17 +090064._gd_init: .long (_sh_start - GENERATED_GBL_DATA_SIZE)
65._stack_init: .long (_sh_start - GENERATED_GBL_DATA_SIZE - CONFIG_SYS_MALLOC_LEN - 16)
Simon Glass6c2afb82016-05-14 18:49:29 -060066#._sh_generic_init: .long sh_generic_init